偶然在某个地方看到这个问题,第一反应是两者是有区别的,但是要说的很详细,一时又想不起来。所以在此记录下来。
首先,java中整数的默认类型是int型,浮点数的默认类型是double型。
数值的转换分为隐式转换和显式转换,隐式转换即jvm帮你去做转换,显式即你自己需要进行强制类型转换。
什么时候进行隐式转换呢,存储范围小的向大的转换,如int向long转换(long a = 10;),进行算术运算时(byte a = 1; int b = a + 1;)。显式则形如(byte a = (byte)200;),但是byte a = 1;却不需要强转,因为jvm编译时会先检查值有没有超出变量定义类型的范围,如果超出,则报错;如果没超出,jvm自动帮你转换。
啰嗦了这么多,进入正题,看下a+=1和a=a+1的区别。首先看一段代码:
byte a = 1;
a += 1;
a = a + 1;//该行会报错
a为byte型,a+=1没有报错,a=a+1却报错了,来看下为什么会报错。前面说到1默认是int型,a为byte型,a+1有算术运算符,所以a会发生隐式转换变为int型,a+1的结果为int型,而a本身为byte型,不能直接赋值,需要强转,改为a=(byte)(a+1);就不会报错了。
那么a+=1为什么就不报错呢,反编译看下,发现就是上面我们修改后的结果a=(byte)(a+1);也就是碰到简式运算符,jvm自动帮我们做了转换。
当然,这里a定义为long型,两个都不会报错。
有错误还请指正。