加减法运算及其溢出处理


一、加减法的溢出处理

1.溢出的定义

◆当运算结果超出机器数所能表示的范围时。
◆ 与最高位产生的进位区别:自动丢弃。
◆ 什么情况下会产生溢出?
➢ 两个异号数相加或两个同号数相减(不会溢出)
➢ 两个同号数相加或两个异号数相减(可能溢出)

2.溢出的判别方法

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
(3)fA=0,fB=0,fS=1≠0,故溢出
(4)fA=1,fB=1,fS=0≠1,故溢出

在这里插入图片描述
在这里插入图片描述
从末尾往前推考虑数值最高位是否进位,符号位是否进位。
(1)fA=0,fB=0,Cf=0(A,B直接运算产生的进位)C=0(数值最高位产生的进位)
(2)fA=1,fB=1,Cf=1(A,B直接运算产生的进位)C=1(数值最高位产生的进位)
(3)fA=0,fB=0,Cf=0(A,B直接运算产生的进位)C=1(数值最高位产生的进位)溢出
(4)fA=1,fB=1,Cf=1(A,B直接运算产生的进位)C=0(数值最高位产生的进位)溢出
(5)fA=0,fB=1,Cf=1(A,B直接运算产生的进位)C=1(数值最高位产生的进位)
(6)fA=0,fB=0,Cf=0(A,B直接运算产生的进位)C=0(数值最高位产生的进位)
例题:
在这里插入图片描述

在这里插入图片描述
较为推荐第三种方式判断溢出,形式简单记忆方便。三种判别方法只需掌握一种即可。
例题:
在这里插入图片描述

二、补充知识

1.移位

推荐补充文章:移位运算用法的总结
1、算数移位 无论正数还是负数,移位后其符号位均不变,且移位后都相当于对真值补0。
2、逻辑移位 将操作数视为无符号数,左移时,低位添0;右移时,高位添0。
补0是相对真值补0,右移是补码右移。
在这里插入图片描述

2.有符号数和无符号数之间的转换

符号位上的值直接变成数值
在这里插入图片描述

3.不同字长数整数之间的转换

补0的原则是要尽量不改变原有数值,有符号的默认最高位为符号位,符号位要保留单独处理。
在这里插入图片描述

4.定点数表示法

我们知道+111和+0.111的原码同为0111,这是因为约定的小数点位置不同,整数的原码小数点约定在末尾,纯小数的原码小数点约定在数值最前面,这样通过约定小数点的位置来表示数的 方法就称为定点数表示法,约定小数点位置实际上就是约定编码中每一位的权重。(对于纯小数来说,小数点在符号位后面,但它不显示也不占位;对于整数来说,小数点就确定在末尾,同样是不显示也不占位)


  • 9
    点赞
  • 32
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
补码是计算机中表示有符号整数的一种方法。在补码中,正数的补码与其原码相同,而负数的补码则是其原码取反后再加上1。补码的加减法运算与无符号整数的加减法运算类似,但需要注意溢出问题。以下是补码的加减法运算溢出判别的详细介绍: 补码的加法运算: 1. 将两个加数的补码对应位相加,得到一个二进制数。如果这个二进制数的最高位(符号位)为0,则表示结果为正数;如果最高位为1,则表示结果为负数。 2. 如果相加的两个数都是正数,且结果为负数,则表示发生了溢出。 3. 如果相加的两个数都是负数,且结果为正数,则表示发生了溢出。 4. 如果一个数为正数,另一个数为负数,则不会发生溢出。 补码的减法运算: 1. 将被减数的补码与减数的补码取反后再加1,得到一个新的补码。 2. 对新的补码执行加法运算,得到一个结果。如果结果的最高位为0,则表示结果为正数;如果最高位为1,则表示结果为负数。 3. 如果被减数和减数符号相同,结果符号与它们相反,则表示发生了溢出。 4. 如果被减数和减数符号不同,则不会发生溢出溢出的判别: 1. 对于加法运算,如果相加的两个数都是正数,且结果为负数,或者相加的两个数都是负数,且结果为正数,则表示发生了溢出。 2. 对于减法运算,如果被减数和减数符号相同,结果符号与它们相反,则表示发生了溢出

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

君知燕云归

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值