11 标志寄存器

本文详细介绍了8086CPU的标志寄存器(Flag),包括其特殊作用和16位结构。重点讲解了零标志位(ZF)、奇偶标志位(PF)、符号标志位(SF)、进位标志位(CF)和溢出标志位(OF)的功能,并通过举例说明如何影响CPU执行。此外,还讨论了ADC、SBB和CMP指令的用法,以及条件转移指令如何根据标志寄存器决定执行路径。最后提到了方向标志位(DF)在串传送指令中的作用,以及如何通过PUSHF和POPF指令直接访问标志寄存器。
摘要由CSDN通过智能技术生成

1、CPU内部的寄存器中,有一种特殊的寄存器(对于不同的处理机,个数和结构都可能不同)具有下面三种作用

(1)用来存储相关指令的某些执行结果;

(2)用来为CPU执行相关指令提供行为依据;

(3)用来控制CPU的相关工作方式。

这种特殊的寄存器在8086CPU中,被称为标志寄存器。8086CPU的标志寄存器有16位,其中存储的信息通常被称为程序状态字(PSW)。我们已经使用过8086CPU的ax,bx,cx,dx,si,di,bp,sp,IP,cs,ss,ds,es等13个寄存器了,接下来我们要学最后一个寄存器(flag)

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


这一节,我们学习CF、PF、ZF、SF、OF、DF

 

2、ZF标志

flag的第六位是ZF,零标志位。他记录i相关指令执行后,其结果是否为0.如果结果为0,那么ZF=1;如果其结果不为0,那么ZF=0

在8086CPU的指令集中,有的指令的执行是影响标志寄存器的,比如,add、sub、mul、div、inc、or、and等,他们大都是运算指令(进行逻辑或算术运算);有的指令的执行对标志寄存器没有影响,比如mov、push、pop等,他们大都是传送指令。在使用一条指令的时候,要注意这条指令的全部功能,其中包括,执行结果对标志寄存器的哪些标志位造成影响

 

3、PF标志

flag的第二位是PF,奇偶标志位,他记录相关指令执行后,其结果的所有bit位中1的个数是否为偶数。如果1的个数为偶数,pf=1,如果为奇数,那么pf=0.

 

4、SF标志

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

 

5、CF,OF标志位

flag的第零位是CF,进位标志位。一般情况下,在进行无符号运算的时候,他记录了运算结果的最高有效位向更高的进位值,或从

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值