无符号数和有符号数的溢出判断

     因为学了微机原理的课程,发现好多人对无符和有符的判断很迷(meng)茫(bi),所以决定总结一下。


无符号数溢出判断:其实很简单,就一句话:

           当最高为向更高位有进位(或借位)时产生溢出。

就像这样:

  无符号数和有符号数的溢出判断_第1张图片

有符号数溢出判断:

       高潮来了:

               最高位进位状态⊕次高位进位状态=1,则溢出

怎么理解呢?

首先要知道(异或)是什么:相同为0,相异为1

然后是“状态”一词,状态指的是有没有进位

那这句话的意思就是:最高位和次高位,一个有进位一个没有进位,则他们的状态异或得1,则结果就有溢出。

直接上例子:

无符号数和有符号数的溢出判断_第2张图片

反正只要记住最高位和次高位进位状态不同,他们溢出就行了。



然后我们来看一下微机原理里面判断of位的经典例题:

   将1001 1100和1110 0101相加后,标志寄存器中OF为何值?

        首先,我们都知道OF为溢出标志位(有溢出为1,无溢出为0),然后,他的定义就是判断补码运算时的溢出情况,既然是补码,那就一定是有符号   数。

那就用判断有符号数溢出的方法判断,先进行运算:

无符号数和有符号数的溢出判断_第3张图片

由此看出(大家自己看吧),最高位有进位,次高位也有进位,则没有溢出,则OF=0


 














你可能感兴趣的:(无符号数和有符号数的溢出判断)