Java基础|聊聊char的初始化及占位字节和类型转换!

一:char的初始化姿势?

char 是 Java 中的保留字,与别的语言不同的是,char 在 Java 中是16位的,因为 Java 用的是 Unicode。不过8位的 ASCII 码包含在Unicode 中,是从0~127。
Java 中使用Unicode的原因是,Java 的 Applet 允许全世界范围内运行,那它就需要一种可以表述人类所有语言的字符编码。Unicode。但是English,Spanish,German, French根本不需要这么表示,所以它们其实采用ASCII码会更高效。这中间就存在一个权衡问题。
因为 char 是16位的,采取的 Unicode 的编码方式,所以char就有以下的初始化方式:
  char c='c'; //字符,可以是汉字,因为是 Unicode 编码
  char c= 十进制数,八进制数,十六进制数等等; //可以用整数赋值
  char c='\u数字'; //用字符的编码值来初始化,如:char='\0',表示结束符,它的 ASCII 码是0,这句话的意思和 char c=0 是一个意思。
 

二:char占几个字节?

1:“字节”是byte,“位”是bit ;1 byte = 8 bit ;
2:char 在 Java 中是2个字节。
Java 采用 unicode,2个字节(16位)来表示一个字符,也就是说一个char类型的变量可以存储一个汉字。(当然兼容ACSII码)
而ASCII码,是1个字节(8位)来表示一个字符。
    通常gbk/gb2312编码是2个字节,utf-8编码是3个字节。

三:类型转换关系图

Java基础|聊聊char的初始化及占位字节和类型转换!_第1张图片

 

Java基础|聊聊char的初始化及占位字节和类型转换!_第2张图片

你可能感兴趣的:([JavaSE]_[基础总结])