**+= 运算符的注意事项—->自动转换;
1. +=运算符**
x+=5 <=??????=> x = x + 5;
+=: 如果发现计算结果和赋值的变量类型不一样的,会自动加上强制转换语句
比如:
正确的案例:
short s = 10;
s+=10; ===> s = (short)(s + 10)
int a = 10;
s+=10; ===> s = s + 10 ;
错误的案例:short x = 10;
x = x+10; //等号左边是short型,等号右边是( short + int ) 自动 转成了int型,所以编译报错。
2.编译器对常量的优化,对变量的不优化,对小数的不优化,需要自己强制转换
a.编译器 对byte 和 short 进行常量赋值时 会进行优化
(只要int常量值没有超过byte或short范围,就会自动强制转换)
int a = 10;//不报错;
byte b = 20;//不报错,把等号右边的int类型转换成了byte类 型。这就是编译器的优化
b.编译器 对byte 和short 进行变量赋值时,不会进行优化,
int a = 10;
byte b = a;//报错,因为a是变量,变量在编译时期编译器不知道它是几,只知道它是int类型,所以对这种变量赋值不会优化。需要自己强制转换!!
c.例子:
float f = 3.14;//报错,小数编译器不会优化
float f = 3.15F; // 正确