美文网首页
为什么两个byte类型的变量相加会报错?

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

作者: doMyselfzy | 来源:发表于2015-12-02 21:42 被阅读3443次

    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类型的变量相加会报错?

          本文链接:https://www.haomeiwen.com/subject/ewfshttx.html