为什么负数存储要取反加 1 ?

本文解释了计算机中二进制表示的源码、反码和补码的概念,以及它们在正负数表示和减法运算中的应用。通过举例说明了为何使用补码进行计算的原因,并探讨了int类型大小的限制。最后建议读者通过实践计算来深化理解补码计算过程。
摘要由CSDN通过智能技术生成

概念

源码:正常数据用二进制表示 (5 , 0000 0101)
反码:源码取反 (-5, 1111 1010)
补码:反码加 1(-5, 1111 1011)

正数的源码反码补码都是一样的,可以理解为都是源码(我是这样理解的)
负数的源码反码补码就是用上述概念表示

原因

计算机如何计算减法?以最高位为 0 代表正数,最高位为 1 代表负数
那么计算 3 - 1,
即 0000 0011 - 1000 0001,
即 - (1000 0001 - 0000 0011)
即 -(129 - 3) = -126
即 1111 1110
结果完全不符合
但是如果用补码表示 -1,来计算 3 + (-1)
即 0000 0011 + 1111 1111 = 1 0000 0010
因为结果 1 0000 0000 中 1已经没有 bit 位表示,因此结果为 0000 0010
结果符合

这也就是为什么 int 类型占 8 字节 32 个 bit,而大小则是 -2^31 到 2^31,而不是 -2^32 到 2^ 32,因为最高位要表示符号位

如果还是不清楚,也许可以自己尝试计算 n + (-m),计算过程中 -m 用补码表示,可能会理解

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值