byte类型运算的问题
byte b1 = 3, b2 = 4, b;
1.b = 1;
检查右边是否在-128~127之间,超过这个数值便会报错。
2.b = b1+b2;
会报错,因为byte类型再相加的时候,会自动转换成int类型,右边的int类型赋值给byte类型便会报错,加上强制类型转换可以通过编译。比如b = (byte)(b1+b2);
3.b=3+4;
不会报错,右侧属于常量,未超过byte的存储范围。
4.b++;
不会报错,b++ 等价于 b = (byte)(b+1) ,因为底层会自动进行强制类型转换。
5.b = b + 1;
报错,byte类型和int类型相加的时候,因为不知道结果会不会溢出,于是会先转化为int类型再进行运算,所以在这条语句中 b + 1 实际上是int类型,所以不能复制给byte。
6.b = 128;
会报错,因为右边超过了byte的存储范围,强制类型转换 b = (byte)128;可以通过编译,但是会造成数据丢失。