【笔记】CPU是如何检测溢出的?

问题:CPU是如何检测溢出的?

    在加法和减法运算完成后,CPU使用一种非常有趣的方法确定溢出标志的值:运算结果最高有效位的进位值(即CF的值)与到最高有效位的进位值异或,其结果放到溢出标志中。例如8位二进制数 1000 0000 和 1111 1110 相加,第6位向最高有效位(第7位)无进位,但是第7位向高位有进位值(CF=1):

        第6位到第7位没有进位

CF = 1 ←   1000 0000

          +    1111 1110

---------------------------------

          =    0111 1110

由于1 XOR 0 = 1,因此:OF = 1

 

 

注:《Intel汇编语言程序设计》第五版

转载于:https://www.cnblogs.com/cloudeman/archive/2012/02/27/2370489.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值