原文链接:https://blog.csdn.net/LYRIC_315/article/details/47608063
首先看一下下列代码
byte b1=1,b2=2;
b3=b1+b2;
final byte b4=4,b5=5;
b6=b4+b5;
问b3和b5能否正常赋值?
答案应该是:b3不能正常赋值,需要类型转换,b3=(byte)(b1+b2);b6能够正常赋值。
原因分析:
在Java中,在基本类型进行算术运算的时候,会发生小字节类型向大字节类型转换的现象。对于short,byte,char 比int 字节数小的变量类型来说,运算结果会自动转换为int类型。Java编译器会在编译期或者运行期将byte和short类型的数据带符号扩展为相应的int类型数据,将boolean和char类型数据零位扩展为相应的int类型数据。因此,在处理boolean 、byte、short 和 char 类型的数组是,也会用相应的int类型的字节码指令来处理。因此,大多数对于上述类型数据的操作,实际上都是使用相应的 int 类型作为运算类型。如下:
short a=1, b=2;
short c=a+b;
System.out.println(c);
在编译时,会报出“Exception in thread "main" java.lang.Error: Unresolved compilation problem: Type mismatch: cannot convert from int to short”,可以看出可以看出a+b结果变成了int类型。
重点来了,如果是final 修饰的变量,进行运算的时候则不会出现类型转换异常。
final short a=1, b=2;
short c=a+b;
System.out.println(c);
这么操作完全OK,究其原因,对于final 修饰的基本类型的变量来说,他们之间的运算直接就被硬编码成了直接赋值语句,连中间结果都没有了,类型转换的异常也就没了。