byte类型的取值范围为什么是-128~127

原码:用二进制表示的原始编码,
反码:除符号位外,其它位取反
补码:正数的补码等于原码,负数的补码等于反码加1

        关于数据类型表示的数据范围问题, 这里byte类型表示的是-128~127 , 为什么不是-127~127 ?其实不光是byte类型,诸如byte、short、int、long等涉及到有符号的数据内向都存在负数表示要多一位的问题, 为什么是这样的呢?

        byte是占一个字节,1一个字节由8位二进制数组成,这8位分为符号位(最高位)和数值位(剩余七位),符号位0表示正数,1表示负数。

       由上面得到(+127:0111 1111、+1:0000 0001、+0:0000 0000、-0:1000 0000、-1:1000 0001、-127:1111 1111)

      +0和-0都表示0,其实是没有意义的,所以计算机就用10000000表示-128;

猜你喜欢

转载自blog.csdn.net/m0_46979453/article/details/121319012