short s = 3;
s = s + 5;
s += 5;
运算结果是 s = s + 5; 这句话编译错误,因为 s+5后,数值类型强制转换成了int型,
再赋值给一个short变量是,会丢失精度,出现编译错误
但是s += 5; 这个运算过程是怎样的,原理是什么,为什么这个就可以编辑通过呢?
short s = 3;
s = s + 5;
s += 5;
运算结果是 s = s + 5; 这句话编译错误,因为 s+5后,数值类型强制转换成了int型,
再赋值给一个short变量是,会丢失精度,出现编译错误
但是s += 5; 这个运算过程是怎样的,原理是什么,为什么这个就可以编辑通过呢?
隐式类型转换可以从小到大自动转,即byte->short->int->long
如果反过来会丢失精度,必须进行显示类型转换
s=s+1这句先执行s+1然后把结果赋给s,由于1为int类型,所以s+1的返回值是int
所以将一个int类型赋给short就会出错,
s+=1不同由于是+=操作符,在解析时候s+=1就等价于s = (short)(s+1),翻番来讲就是
s+=1 <=> s = (s的类型)(s+1)