一、性能方面
a=a+b是加法运算 需要两次寻找地址而a+=b是增量运算有寄存器优先时 只有一次地址查找。效率方面后者略高于前者,基于现在计算机的发展可忽略不计。
二、可读性方面
两者都是赋值运算,一般情况下可以认为两者没有什么区别,但前者与数学算法描述更接近相对来说更严谨而后者书写更快捷但可读性下降。
三、数据类型方面
两者写法上主要在于是否能进行数据类型自动转换,事实上就是类型与精度上的差异。eg:当两个操作数的数据类型一致时两种形式的运算结果没有差别,但数据类型不同且a值的数据类型精度低时,此时两种形式就有区别了。
定义a是short类型变量,执行a+=b[b为int类型的20值]时,输出结果为30,自动将int为20的类型转换int。代码稍微调整一下,调整为a=a+b结构时,就报错
"+="这个运算符是一个运算符,程序在执行“+=”时,会自动向高精度类型转换,即a+=20 编译通过;而“=”要求两边类型一致,a=a+b结构中,a是short类型变量,而b为int类型常量,此时(short类型+int类型)出现类型不匹配问题。
注:b为变量且明确申名了变量数据类型时 则a+=b与a=a+b 都存在类型转换问题 需强制进行类型转换
若强行用short类型去接收int类型的数据 可以进行强类型转换 但最终导致结果是精度丢失。