计算机组成原理-定点数运算以及溢出检测

定点数运算以及溢出检测

  • 定点数加法运算

    • [X]补+[Y]补=[X+Y]补 mod 2^(n+1)

      • 关于mod的一些解释

        • mod"是数学中的取模运算,通常表示为符号"%",表示除数除以被除数后所得到的余数。

        • 如果被除数 本身小于除数那么 得到的结果就是被除数本身

          • 比如 11mod12=11
      • n表示有效位

    • 例子

    • 在这里插入图片描述

  • 定点数减法运算

    • [X-Y]补=[X]补-[Y]补=[X]补+[-Y]补

    • 如何求[-Y]补

      • 1.按着原码和补码的关系求(比较繁琐)
      • 2.扫描法
      • 例子
      • 在这里插入图片描述
    • 例子

    • 在这里插入图片描述

  • 数溢出的概念和判断方法

    • 概念

      • 运算结果超出了某种数据类型的表示范围
    • 检测的方法

      • 溢出这可能发生在同符号数相加时,包括[X]补与[Y]补;[X]补与[-Y]同号;

      • 方法1

        • 对操作数和运算结果的符号位进行检测

          • 当结果的符号位与操作数的符号不同时就表明发生了溢出
      • 方法2

        • 对最高数据位进位和符号进位进行检测

          • 设运算时最高数据位产生的进位为C1,符号位产生的进位为C0

            • 溢出检测电路为:V=C0⊕C1 ⊕表示异或运算 不同步则就是发生了溢出
      • 方法3

        • 用变形补码

          • 双符号位
          • [X]补=Xf1Xf2 X1 X2…Xn mod 2^(n+2)
          • 溢出判断
          • 例子
          • 在这里插入图片描述
    • 无符号数运算的溢出判断

      • 无符号数加法的溢出可用ALU的进位表示
      • 无符号数减法的溢出可用带有加/减功能的ALU的进位取反后表示
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 4
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值