在刚接触C语言时,书上说byte型为有符号8位整数,占1个字节,取值范围在-128~127
int为有符号32位整数,占四个字节,取值范围是-2147483648~2147483647......
当时只想记住范围,没有想过存储原理,只知道书上记载因为一个字节中,第一个二进制数为符号位(0为正号,1为负号),因此byte的数据范围最大值为2^7 - 1 = 127
仔细想想,虽然明白正数被占据一个符号位,其余二进制位全部为1的最大值确实为127,但是为什么负数的范围却比正数大呢?
查阅资料后发现,计算机在存储二进制数据时,使用补码存储,正整数的补码是它本身,负数的补码是它的反码加一
要想真正理解计算机的数据存储,必须明白二进制存储数据的编码方式:原码、反码、补码
- 原码:数据的原码是符号位加上真值,即十进制1的原码为00000001,十进制-1的原码为10000001
- 反码:除符号位外,所有的真值在原码的基础取反,即十进制1的反码为01111110、十进制-1的反码为11111110
- 补码:正整数的补码为它本身,负数的补码为其反码+1
这样我们就能理解,为什么byte存储的最小值为-128?
由于数据存储使用补码,所以负数的最小值为10000000,其补码为11111111,第一个为符号位,即最小值为-(127+1) = -128