整数在内存中的存储使用的是二进制表示法,有三种常见的表示方式:原码、反码和补码。
首先声明,正数原码反码补码是一样的,最后会详细说明
-
原码:直接将数值按照正负数翻译为二进制数,最高位是符号位,0代表正数,1代表负数,其余位表示数值部分。
-
反码:原码的符号位不变,数值部分按位取反得到。负数的反码是符号位不变,其他位按位取反。
-
补码:反码的基础上加1得到。负整数的原码、反码、补码不相同。
原码的话大家都好理解,正数和负数只有符号位的不同,那么为啥负数的事这么多呢?下面就介绍反码和补码
反码,是因为负数加上一个数会造成相反的结果而出现的
例如 -56 (1011 1000) 如果用原码加上1,会得到-57这样的错误结果。因此,我们对负数进行除符号位取反的操作来解决这个问题。
到这里,你可能要问了,既然反码已经解决了负数相加的问题,那么再有补码岂不是多此一举,其实不然。
补码,其实是因为使用反码计算时,如果遇到数字跨0的情况便会多加一次造成误差
十进制 | 原码 | 反码 | 补码 |
0 | 0000 0000 | 0000 0000 | 0000 0000 |
-0 | 1111 1111 | 0000 0000 | 0000 0000 |
1 | 1000 0001 | 1111 1110 | 1111 1111 |
通过对负数的反码加1,完美的解决了正负数相加的问题,所以反码和补码根本上是为了负数诞生的,这下,你该理解这玩意的用处了吧。