1.先看以下代码
public classMain {
public static void main(String[] args) {
byte a =4;
byte b =6;
byte c = a + b;
}
}
以上代码在编译过程中就会报错。
2.分析:
为什么byte a = 4;就不会报错?
因为byte是一个字节,八个二进制位,此时其范围为-128 ~ +127,所以4在其范围内,所以可以被赋值。一旦这个数值超过了127,那么编译就会报错了。
为什么byte c = a + b;就报错呢?
这是java的机制导致的,java在对byte这种类型进行“运算”时,会将其转换为int类型,两个int类型相加,赋值给byte类型肯定会报错的。
为什么byte = 3 + 4;又不会报错呢?
跟第一个一样,3+4是常量的计算,会优先执行,执行结果再赋值给byte,此时判断数值是否满足该类型范围,满足就直接赋值了。
3.总结
两个变量相加,先对类型进行提升,然后运算,再将运算结果赋值。
两个常量相加,先计算常量数值,然后判断是否满足类型范围,再赋值。
网友评论