在内存中,最高位(最左)不是表示大小的,而是表示这个数的正反,0代表正数,1代表负数,所以最高位又叫符号位
0000 1000 = 8 1000 1000 = -8计算机不会做除了加法之外的所有运算,所以便有了
8 + 4 = 4 0000 1000 + 0000 0100 = 0000 1100 = 12
8 - 4 = 4 0000 1000 + 1000 0100 = 1000 1100 = -12
这在现实中是不正确的计算,为了避免这种乌龙,在内存中所有的储存和计算都是以补码进行的原码:即是其二进制表现形式
反码
- 正数的反码和原码相同
- 负数的反码是符号位不变,其余位按位取反
补码
- 正数的补码和原码相同
- 负数的补码是反码+1
在知道了运算都是基于补码进行之后,上文中所提到的不合理就迎刃而解了
8 - 4 = 0000 1000 + 1111 1100 = 1 0000 0100 = 4
高位溢出,舍去最前面的1,最后为4
版权声明:本文为wenok147原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。