本文从Java语言进行阐述。
在学习运算符章节时,有这么一道题,经查询还是一道校招的面试题:
byte a = 111;
a = a +5和 a +=5 是否运算结果一样?
如果回答一样,面试马上挂掉。
下面我们分开来看:
情况一:
byte a =111;
a = a +5;
编译器会报错,具报错代码如下:
分析报错原因:
由于a为byte型,当执行第二句代码时a = a +5,右侧代码会存在自动类型提升,整体代码会转为int型,而int型在内存中占4个字节放入byte会造成溢出现象,此为报错原因。
解决方法:要么统一数据类型,要么进行强制类型转换,如,a = (byte) (a+5);
情况二:
byte a =111;
a += 5;
编译顺利通过,并输出正确结果:116。
这是为何?
经百度搜索,发现有人说a +=5 做了自动类型提升,但没有强转;而有人说,a +=5实际上是隐形的强制转换。
到底哪种说法是正确的?我们通过IDE实际编码测试以下:
测试代码如下:
int a =1;
a += 3.145672;
System.out.print(a);
编译器结果为:4
okay,到此我们可以得出结论:
+= 诸如此类的扩展运算符,实际上确实是一种隐形的强制类型转换。