为什么两个byte类型的变量相加会报错?

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.总结

两个变量相加,先对类型进行提升,然后运算,再将运算结果赋值。

两个常量相加,先计算常量数值,然后判断是否满足类型范围,再赋值。

你可能感兴趣的:(为什么两个byte类型的变量相加会报错?)