补码原理&一个字节存储数值的范围如何计算

为什么二进制负数在计算机中的存储需要使用补码?一个字节存储数值范围为什么是-128~127?下面我们开始学习。

1.了解补码

什么是原码、反码和补码?负数在计算机中的二进制表示是怎样的?(戳这里查看

2.补码原理

负数为什么要用补码表示?(戳这里查看

从引用链接中我们也不难发现补码有以下特性:

  • 原码与补码相加,和为模。
  • 正数的补码等于其本身。
  • 补码正零、负零表示方法相同。

3.一个字节存储数值范围

一个字节有八位,能存储的最大正数为01111111,其中首位0是符号位,表示数值为正。数值部分转换为十进制为:

2^6+2^5+......+2^0=\frac{1-2^7}{1-2}=127

一个字节能存储的最小负数的补码为10000000。由补码的补码为原码可得:

10000000(求反码)——>11111111(求补码)——>1 00000000(化为十进制)——>-128

所以一个字节存储数值范围是-128~127。

为描述简洁,下面只考虑四位。下图(引用自)列出了四位二进制数所有可能表示数字的原码、反码和补码。

我们可以看出,正零和负零的原码是不同的,但存储的补码是相同的(或者说用1 0000表达了-0)。所以,对于补码来说,就多出了1000这种表达方式。虽然-8的原码超出了四位能表达的范围,但是其补码却能用四位表达,而计算机存储的正是补码。所以,存储范围下限的绝对值比上限大1。一个字节同理。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值