java中short、byte、char等类型的变量在参与运算时会先被隐含地转换为int类型,再参与运算。
例如:
short a=3,b=4,c;
c=a+b;
System.out.println(a);
此时编译器会报错:可能会损失精度
这是因为a和b在参与运算之前会被隐式转换为int型,两个int型数据相加后依然是int型数据,这样“c=a+b”相当于把int型的数据赋值给了short型,会报损失精度的错误。
可改为:
c=(short)(a+b);
就不会报错了。
另外,对于“++”、“-=”、“*=”、“/=”等扩展的算术运算符,其操作数在计算时会隐含地添加强制类型转换机制,使表达式正确。
如:
short a=3,b=4;
b+=a;
System.out.println(b);
这样编译时是不会报错的,因为编译器隐含地为“b+=a”添加了强制类型转换,相当于b=(short)(a+b);
另外,注意在java中char型数据占两个字节,这与c/c++有所不同。