【计算机组成原理】对原码与补码的理解

以上例子皆以8位计算机存储为例

原码

最高位是符号位,0代表正数,1代表负数,其余7位是数值位,也就说正数的最大值是(01111111)_{2}=(127)_{10},负数的最大值是(11111111)_{2}=(-127)_{10},但是问题是(00000000)_{2}=(+0)_{10}以及(10000000)_{2}=(-0)_{10}两个0重复了,浪费了一个8位2进制数。

补码:

正数的补码=原码,负数的补码=原码取反+1,那么(+0)_{10}=(00000000)_{2}(-0)_{10}=(00000000)_{2},正负两个0都用一个二进制来表示,那么(10000000)_{2}这个二进制就空着了,因为(-127)_{10}=(10000001)_{2},那么顺理成章(-127)_{10}-(1)_{10}=(-128)_{10}=(10000000)_{2},这样每一个8位二进制数代表的数就不一样了

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值