无比菜鸟 发表于 2011-7-24 16:53:46

cpu 如何判断数据是否溢出(转贴)

转个贴,觉得挺有用,刚开始我也没想明白这个问题,还以为每次cpu都需要对比范围(如8位寄存器,-128~127)才能判断结果是否溢出,来给出of的值。

针对有符号数,CPU只要在运算结束后比较一下最高位符号位是否产生变化就能判定溢出情况了!
比如:
11110000
+10001000
-——————                        
01111000 即78h
运算前,两个操作数最高位都为1,证明都是负数,而运算结果的最高位为0,符号位产生了变化,这就证明运算溢出了!
当然这种判断只局限于(正数+正数)和(负数+负数)的运算,因为(正数+负数)是不会产生溢出的,所以CPU根本就不用进行判断。

说了你未必会懂 发表于 2011-7-24 17:04:08

恩,看懂了,这纠结于此问题呢,转的真及时啊!

无比菜鸟 发表于 2011-7-24 17:18:15

说了你未必会懂 发表于 2011-7-24 17:04 static/image/common/back.gif
恩,看懂了,这纠结于此问题呢,转的真及时啊!

恩 {:5_109:}!!加油!

udsky 发表于 2011-7-24 23:39:58

谢谢分享!

coko 发表于 2013-7-2 16:39:42

看帖,就必须回帖
页: [1]
查看完整版本: cpu 如何判断数据是否溢出(转贴)