short s=1;
s+=5; //编译通过。
s=s+5; //编译失败。s已确定为short类型,int赋给short损失精度或溢出。需要强制转换。
+=作为增强型的赋值语句,在一般情况下没什么差别。
但在运算操作数精度不同时,有差别。
+:在编译器将右边的表达式结果计算出来后,和左边的变量类型比较精度,如果左边的变量精度低于右边的结果的精度,编译器会显式的报错,告诉程序员去强制转型。最后将表达式的结果复制到变量所在的内存区。
+=:编译器自动隐式直接将+=运算符后面的操作数强制转换为前面变量的类型,然后在变量所在的内存区上直接根据右边的操作数修改左边变量内存存储的二进制数值,最后达到和赋值运算符相同的目的。与前者相比,由于后者是位操作,效率也较前者高。
参考博客:https://blog.csdn.net/zhugewendu/article/details/72729786
另:
- +=和=+
- python的增强赋值
Java是这样么?String的+对内存是怎么操作的?