1. +=运算符的自动强制转换 和 2.编译器对常量的优化,对变量的不优化,对小数的不优化,需要自己强制转换

**+= 运算符的注意事项—->自动转换;
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;  // 正确

猜你喜欢

转载自blog.csdn.net/qq_32367263/article/details/81322582