Char类型的运算

2017-06-19  本文已影响0人  博为峰51Code教研组

[面试原题]

假设y是字符类型,初始化值为‘b’,那么以下语句输出的结果是什么?

A.System.out.println(++y);

B.System.out.println(y+1);

[正确答案]

A.‘c’

B.99

[面试技术点]

字符在java中的运算。

[解读A]

char在java中称为“字符型”,占2个字节。字符常量是用单引号括起的一个字符,且字符常量在内存中存储的是该字符在Unicode字符集中的排序位置,即整数。

比如:

char y='b';

内存y中存储的是字符’b’在Unicode字符集中的排序位置98。【可以通过语句System.out.println((int)y);来获取Unicode的排序位置。】因此上面的语句也可以写成:

char y=98;

System.out.println(++y);语句,先执行++y,结果为99,然后输出对应位置的字符’c’。

[解读B]

博为峰小博老师在这里要给大家说一个概念,java中的“向上兼容”,即:不同数据类型的数据参与运算,数据类型要强制转换,转换的方向是:char->short->int->long->float->double。

在System.out.println(y+1);这个语句中,y是char类型,1是int类型,所以把y强转成int,然后运算结果是99,输出也是int类型99。

[扩展]

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='a'; //字符,可以是汉字,因为是Unicode编码,如char c=’我’,内存对应的unicode值为:25105。

char c=十进制数,八进制数,十六进制数等等; //可以用整数赋值

char c='\u数字'; //用字符的编码值来初始化,如:char='\0',表示结束符,它的ascll码是0,这句话的意思和char c=0是一个意思。

Unicode编码表:

上一篇下一篇

猜你喜欢

热点阅读