补码

概念

补码:英文 two‘s-complement;计算机对有符号的数字的表示方式有三种:原码、反码、补码;

三者之间的关系

正数:补码 = 原码 ;反码是原码各位取反;
负数:补码 = 反码 + 1;反码是原码各位取反;

模和补数

以下解释来源于百度百科:
“模”是指一个计量系统的计数范围。如时钟等。计算机也可以看成一个计量机器,它也有一个计量范围,即都存在一个“模”。例如:
时钟的计量范围是0~11,模=12。表示n位的计算机计量范围是0~2^(n)-1,模=2^(n)。
“模”实质上是计量器产生“溢出”的量,它的值在计量器上表示不出来,计量器上只能表示出模的余数。任何有模的计量器,均可化减法为加法运算。
例如:假设当前时针指向10点,而准确时间是6点,调整时间可有以下两种拨法:一种是倒拨4小时,即:10-4=6;另一种是顺拨8小时:10+8=12+6=6;

对于计算机,其概念和方法完全一样。n位计算机,设n=8, 所能表示的最大数是11111111,若再加1成为100000000(9位),但因只有8位,最高位1自然丢失。又回了00000000,所以8位二进制系统的模为2^8。在这样的系统中减法问题也可以化成加法问题,只需把减数用相应的补数表示就可以了。把补数用到计算机对数的处理上,就是补码。

代数

代数解释
在十进制中我们可以把n位二进制体系中的数
a表示为: 这里写图片描述
求补码,意味着求: 这里写图片描述
而根据等比数列求和公式:
这里写图片描述
这里写图片描述
因为这里k0,k1,k2,k3……不是0就是1,所以1-k0,1-k1,1-k2的运算就是二进制下的取反
注:n位二进制,最高位为符号位,因此表示的数值范围-2^(n-1) ——2^(n-1) -1,所以模为2^n。上面提到的8位二进制模为2^8是因为最高位非符号位,表示的数值范围为0——2^8-1。

根据代数的概念可以推出补码与原码的关系:补码 = 反码 + 1;

补码优势

  • 将减法转换为加法
    比如 5-2 也就是 5+(-2)【8位表示】
    5的补码:00000101
    2的补码:(10000010取反->11111101) +1 = 111111110

0 0 0 0 0 1 0 1(5)
+
1 1 1 1 1 1 1 0(-2)
=
0 0 0 0 0 0 1 1(3)

  • 0的表示唯一

小结

目前几乎所有的计算机系统均采用了补码的编码策略。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值