今天爱分享给大家带来Java中 a=a+b和a+=b有什么区别?【面试题详解】,希望能够帮助到大家。
在java语言中,a+=b和a=a+b的主要区别是在运算的精度上。类似的有“-= 、 *= 、/= 、%= ”,这里以a+=b 与 a=a+b 举例说明一下。
1. 下面是一串代码,我们试一下a=a+b的形式:
public class TestDemo { public static void main(String[] args) { byte a=1; a=a+4; System.out.println(a); } }
从图中可以看出出现了错误,根本无法运行。报错原因我也贴出来了,说是“类型不匹配:不能从int转换为byte”,
这里因为a是byte类型,而数字4默认是int 类型。在java中,在a+4时,会进行 自动类型转换 ,所以a+4 会转换成int类型。而变量a还是byte类型,将int 类型的a+4赋值给byte类型的a ,无疑会报错。
当然,我们也可以进行强类型转换,将已经转换成int类型的a+4强制转换为byte类型,这样也是可以的。但是这种转换可能会导致溢出或者精度的下降,如果容忍可能出现的误差,可以使用这种转换。
下面是转换的结果:
public class TestDemo { public static void main(String[] args) { byte a=1; a=(byte)(a+4); System.out.println(a); } }
2)下面试一试a+=b的形式
public class TestDemo { public static void main(String[] args) { byte a=1; a+=4; System.out.println(a); } }
我们发现结果是正确的,程序也没毛病。大家需要明确的是“+=”是java中的一个运算符,而不是两个,所以在运算时 会进行自动类型转换。所以在编译时没有报错。
(3),总结一下,在两个变量的数据类型一样时:a+=b 和a=a+b 是没有区别的。
但是当两个变量的数据类型不同时,就需要考虑一下数据类型自动转换的问题了。
也就是涉及到精度了。