第11章 标志寄存器

CPU内部寄存器中,有一种特殊的寄存器,被称为 标志寄存器。8086CPU的标志寄存器有16位,其中存储的信息通常被称为 程序状态字(PSW)。具有以下3种作用
(1) 用来存储相关指令的某些执行结果;
(2) 用来为CPU执行相关指令提供行为依据;
(3) 用来控制CPU的相关工作方式;

    flag寄存器和其他寄存器不一样,其他寄存器是用来存放数据的,都是整个寄存器具有一个含义。而flag寄存器是按位起作用的,它的每一位都有专门的含义,记录特定的信息。


11.1 ZF标志

    flag的第6位是 ZF,零标志位。它记录相关指令执行后,其结果是否为0。 如果结果为0,那么ZF=1;如果结果不为0,那么ZF=0。
    在8086CPU的指令集中,有的指令的执行是影响标志寄存器的, 它们大都是运算指令(逻辑或算数运算);有的指令对标志寄存器没有影响, 它们大都是传送指令,比如mov、push、pop等。




11.2 PF标志

    PF,奇偶标志位。它记录相关指令执行后,其结果的所以bit位中1的个数是否为偶数。如果1的个数为偶数,PF=1,如果为奇数,那么PF=0。




11.3 SF标志

    SF,符号标志位。它记录相关指令执行后,其结果是否为负。如果结果为负,SF=1;如果非负,SF=0。

  对于同一个二进制二进制数据,计算机可以将它当作无符号数据来运算,也可以当作有符号数据来运算。不管我们如何看待,CPU在执行add等指令的时候,就已经包含了两种含义,也将得到用同一种信息来记录的两种结果。关键在于我们的程序需要那种结果。
  CPU在执行add等指令时,是必然要影响到SF标志位的值的。 至于我们需不需要这种影响,那就看我们如何看待指令所进行的运算了。

    SF标志,就是CPU对有符号数运算结果的一种记录,它记录数据的正负。我们把数据当作有符号数时可以通过它来得知结果的正负。如果我们将数据当作无符号数来运算,SF的值则没有意义,虽然相关的指令影响了它的值。


    这一小节对我来说需要注意的就是:二进制数据既可以看作无符号数,又可以看作有符号数,运算时不需要区分数据是有符号还是无符号,采用不同的算数运算指令,而是用相同的指令,只要不出现进位、溢出得到的结果都是正确的。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值