概念
原码:将一个整数,转换成二进制,就是其原码。
如单字节的3的原码为:0000 0011;-3的原码为1000 0011。
反码:正数的反码就是原码;负数的反码是将原码中,除符号位以外,每一位都取反。
如单字节的3的反码为:0000 0011;-3的反码为1111 1100。
补码:正数的补码就是原码;负数的补码为反码+1。
如单字节的3的补码为:0000 0011;-3的原码为1111 1101。
在计算机中,正数是用原码表示的,如单字节3,在计算机中就表示为:0000 0011。
负数用补码表示,如单字节-3,在计算机中表示为1111 1101。
负数使用补码的原因
- 扩大表示范围
-
单字节整数,无符号型,表示范围是[0,255],总共表示了256个数据。有符号型,其表示范围是[-128,127]。 java中的byte类型便是如此。
-
无符号类型,0表示为0000 0000,255表示为1111 1111,可以表示256个数据,没啥问题。
再看有符号的,若是用原码表示,0表示为0000 000。因为咱们有符号,所以应该也有个负0(虽然它还是0):1000 0000,反而-128表示不了。 -
所以,计算机中,负数是采用补码表示。
-
如 单字节-1,原码为1000 0001,反码为1111 1110,补码为1111 1111,计算机中的单字节-1就表示为1111 1111。
-
单字节-128,原码貌似表示不出来,除了符号位,最大的数只能是127了,其在计算机中的表示为1000 0000。
- 简化减法运算
通过求补运算,获取对应的正数或负数。
如
原码 反码 补码
-127 -〉127 1000 0001 -〉 0111 1110 -〉 0111 1111
127 -〉-127 0111 1111 -〉 1000 0000 -〉 1000 0001
-128 -〉128 1000 0000 -〉 0111 1111 -〉 1000 0000
128 -〉-128 1000 0000 -〉 0111 1111 -〉 1000 0000
可以发现,负数和正数求补的方法是一样的,负数正数均使用补码表示。
对于实际使用场景,如java中的byte,取值范围为[-128,127]
在计算机中,我们可以看到,对其求补,得到的结果是其数值对应的负数。同样,负数也是如此。所以可以将减法变为加法,省去了减法器
- 无符号及带符号的加法运算可以用同一电路完成。
减法可以转成加法来实现,自然可以用同一电路实现。
微信扫一扫关注该公众号