计算机基础知识

文章讲述了整数如何使用补码进行存储和计算,强调了补码的优点,如无需减法器并通过加法实现减法。还介绍了原码、反码的概念以及特殊数值如-128的补码表示。最后提到解决幂等问题的方法。
摘要由CSDN通过智能技术生成

1.整数为什么使用补码存储和计算?

原码:十进制数据的二进制表现形式就是原码,原码最左边的一个数字就是符号位,0为正,1为负。

反码:正数的反码是其本身,负数的反码是符号位保持不变,其余位取反。

补码:正数的补码是其本身,负数的补码等于其反码+1。符号位也需要参与计算。

如果使用原码做表示,发现2-2=0000 0010+1000 0010=1000 0100=-4,用原码表是不对。

所以考虑逆推,正数+什么样的数A=0,统计规律发现,这样的数为补码形式。

这样好处是,不需要减法器,统一使用加法器能实现减法。

补码表示

2-2=0000 0010+1111 1110=0000 0000,最高位是0,对应原码相同

正负0的补码都是0000 0000,即0的补码只有一种表示。

[-0]原码1000 0000在除符号位外按位取反后得到[-0]反码1111 1111,[-0]反码1111 1111再+1后因为符号位发生了进位,得到[-0]补码1 0000 0000。 9位二进制的[-0]补码1 0000 0000已经超出了8位二进制的位数限制,那只能保留最低的8位二进制,即最高位1要被舍弃,因此最后[-0]补码还是0000 0000

2-1=0000 0010+1111 1111【-1的补码】=0000 0001

-2-1=1111 1110【-2的补码】+1111 1111【-1的补码】=1111 1101【补码】,对应原码1000 0011

特例:-128的补码为1000 0000,8位表达范围就是[-128,127]。

解决幂等问题,只需要记住这个口诀!
 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值