双符号二进制溢出

背景

在计算机计算过程中,如果计算结果超出了当前位数能表示的最大值,则称为正溢(上溢),

如果低于当前位数能表示的最小值,则称为负溢(下溢),那么具体是怎么通过符号位来判断这两种异常情况呢?接下来讨论双符号位二进制的情况。

结论

计算机存储数据采用双浮号位(即00表示正号,11表示负号),两个符号位相同的数增加时:

00 正常运算后的正数符号位

11 正常运算后的负数符号位

01 正溢(上溢)后的正数符号位

10 负溢(下溢)后的负数符号位

这里举两个例子(按照计算机中用补码参与运算的规律,以4位双符号二进制为例):

4位双符号二进制,表示范围[-3,+3]

1 正数相加

(1)正常相加的情况:1 + 1

原码:00 01 + 00 01

反码:00 01 + 00 01

补码:00 01 + 00 01

补码相加得:00 10

(2)正溢相加的情况:3 + 3

原码:00 11 +00 11

反码:00 11+ 00 11

补码:00 11 +00 11

补码相加得:01 10,产生了正溢出

2 负数相加

(1)正常相加的情况:(-1) + (-1)

原码:11 01 + 11 01

反码:11 10 + 11 10

补码:11 11 + 11 11

补码相加得(1)11 10,舍弃最高位,即11 10

(2) 负溢相加的情况:(-3)+(-3)

原码:11 11 + 11 11

反码:11 00 + 11 00

补码:11 01 + 11 01

补码相加得(1)1010,舍弃最高位,即1010,产生了负溢出

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值