在C语言中,整型的内部表示法中都是用最高位表示数值的符号
有符号整数的内部表示因编译器而不同;int型为16位的编译器中,常用的内部表示法如下:
1.反码:反转所有位
01111111 11111111 => 2^15-1=32767
取反码得到
10000000 00000000 => -32767
00000000 00000000 => 0
11111111 11111111 => -0
-0 加1后是0
表示范围:-32767~32767,共65535个值
2.补码:反码的基础上+1
01111111 11111111 => 2^15-1=32767
取反码+1,得到补码
10000000 00000001 => -32767
10000000 00000000 => -32768
00000000 00000000 => 0
11111111 11111111 => -1
能比反码多表示一个数字,表示范围-32768~32767,共65536个值
怎么计算一个负数补码对应的数字呢?
(1)反推
1001 0000 –减1–> 1000 1111 –反转–> 0111 0000 = 112
(2)同样取反+1
1001 0000 –取反–> 0110 1111 –加1–> 0111 0000 = 112
3.符号和绝对值:最高位为符号,其他位为绝对值
10000000 00000000 => -0
00000000 00000000 => 0
10000000 00000111 => -7
00000000 00000111 => 7
能够表示的范围和反码一样,-32767~32767,共65535个值
有符号整数的内部表示因编译器而不同;int型为16位的编译器中,常用的内部表示法如下:
1.反码:反转所有位
01111111 11111111 => 2^15-1=32767
取反码得到
10000000 00000000 => -32767
00000000 00000000 => 0
11111111 11111111 => -0
-0 加1后是0
表示范围:-32767~32767,共65535个值
2.补码:反码的基础上+1
01111111 11111111 => 2^15-1=32767
取反码+1,得到补码
10000000 00000001 => -32767
10000000 00000000 => -32768
00000000 00000000 => 0
11111111 11111111 => -1
能比反码多表示一个数字,表示范围-32768~32767,共65536个值
怎么计算一个负数补码对应的数字呢?
(1)反推
1001 0000 –减1–> 1000 1111 –反转–> 0111 0000 = 112
(2)同样取反+1
1001 0000 –取反–> 0110 1111 –加1–> 0111 0000 = 112
3.符号和绝对值:最高位为符号,其他位为绝对值
10000000 00000000 => -0
00000000 00000000 => 0
10000000 00000111 => -7
00000000 00000111 => 7
能够表示的范围和反码一样,-32767~32767,共65535个值