补码浅析

先上张补码的示例图 以方便理解:


一、模(进制)

    要理解补码,先理解下 模,也可以称作进制。

在日常生活当中,可以看到很多这样的事情: 

  • 把某物体左转 90 度,和右转 270 度,在不考虑圈数的条件下,最终的效果是相同的;
  • 把分针倒拨 20 分钟,和正拨 40 分钟,在不考虑时针的条件下,效果也是相同的; 
  • 把数字 87,减去 25,和加上 75,在不考虑百位数的条件下,效果也是相同的;

        上述几组数字,有这样的关系: 90 + 270 = 360 ;20 + 40 = 60 ;25 + 75 = 100 。式中的 360、60 和 100,就是"模"(也可以理解成"进制")。式中的 90 和 270、20 和 40、 25 和 75,就是一对对"互补"的数字。 知道了"模",求某个数字的"补数",就是轻而易举的了: 如果模为 365,数字 120 的补数为:365 - 120 = 245。 

        前面说过的十进制数 25 和 75,它们是 2 位数的运算,模是100,即 1 的后 面加上 2 个0。 如果有 3 位数参加运算,模就是1000,即 1 的后面加上 3 个 0。 这里的 1000,是十进制数的一千,可以写成 10^3,即 10  的 3 次方。


推论:有多少位数参加运算,模就是在 1 的后面加上多少个 0。 

        对于二进制数字,模也是这样推算。 如果是 3 位二进制数参加运算,模就是1000,即 1 的后面加上 3 个 0; 那么当 8 位二进制数参加运算,模就是1 0000 0000,即 1 的后面加上 8 个 0。 16 位二进制数参加运算,模可就大了,是 1 的后面加上 16 个 0。

计算时加上正数,是不需要进行求取补数的;只有进行减法(或者加上负 数),才需要对减数求补数。 补码就是按照这个要求来定义的:正数不变,负数即用模减去绝对值


示例:用补码计算: 83 - 25 = 58。 

都变成补码,再用加法运算 
(83的二进制):0101 0011 
(-25的二进制): 1 0000 0000(模) -  0001 1001 = 1110 0111 
上面二个进制值相加得: [1]0011 1010 ,忽略进位 1,结果就是 58 。

计算结果如果超出了 -128 ~ 127 的范围,结果将是错误的。


二、”求反加一“

关于”求反加一“:

  • (二进制转换为十进制) 1000 0000  :

反码: 0111 1111。

求反加一: 1000 0000        : 128

因为首位为 1 ,所以为负数,则为 -128。


  • (十进制转换为二进制) -128    :  

128: 1000 0000。

反码: 0111 1111。

求反加一: 1000 0000 。

        可以看出很繁琐,而且还有原码反码概念。其实原码和反码也只不过是"人为"进行"求反加一"时的中间过程,在计算机里面根本是不存在的,它们也就没有丝毫用处。 

个人建议:求取补码,就按照定义的规定,负数采用"模减去绝对值"的方法来求,这是求补数的通用方法,适合于各种进制、各种大小的数字。


  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值