目录
引言
CPU内部的寄存器中有一种特殊的寄存器,被称为标志寄存器,具有以下三种作用,:
(1)用来存储相关指令的某些执行结果;
(2)用来为CPU执行相关指令提供行为依据;
(3)用来控制CPU的相关工作方式。
8086 CPU的标志寄存器只有16位,其中存储的信息通常被称为程序状态字(PSW)。
标志寄存器(简称为flag)。flag寄存器是按位起作用的,每一位都有专门的含义,记录特定的信息,与其他寄存器不一样。
8086 CPU的flag寄存器的结构:
flag的1、3、5、12、13、14、15位在8086 CPU中没有使用,不具有任何含义;而0、2、4、6、7、8、9、10、11位都具有特殊的含义。
11.1 ZF标志
flag的第6位是ZF,零标志位,它记录相关指令执行后,结果为0,ZF=1(记录下是0这样的肯定信息),结果不为0,ZF=0(表示结果非0)。
mov ax,1
sub ax,1
mov ax,1
and ax,0
指令执行后,结果为0,则ZF=1
mov ax,2
sub ax,1
mov ax,1
or ax,0
指令执行后,结果为1,则ZF=0
在8086CPU中,add、sub、mul、div、inc、or、and等它们大多都是运算(逻辑运算或是算术运算)指令,是影响标志寄存器的,而mov、push、pop等传送指令对标志寄存器一般没有影响,因为不会产生结果。
11.2 PF标志
flag的第2位是PF,奇偶标志位。记录指令执行后结果所有的二进制位中1的个数。为偶数,PF=1;为奇数,PF=0。
mov al,1
add al,10
执行结果为00001011B,有3个1,则PF=0
mov al,1
or al,10
执行后结果为00000011B,有2个1,则PF=1
11.3 SF标志
flag的第7位是SF,符号标志位。它记录相关指令执行后,其结果是否为负。如果结果为负,sf=1;如果非负,sf=0。
计算机中通常用补码来表示有符号数据。计算机中的一个数据可以看作是有符号数,也可以看作是无符号数。也就是说,对于同一个二进制数据,计算机可以把它当作无符号数据来运算,也可以当作有符号数据来运算。CPU在执行add等指令的时候,就已经包含了两种含义,也将得到用同一种信息来记录的两种结果。
在我们将数据当作有符号数来运算的时候,可以通过它来得知结果的正负。如果我们将数据当作无符号数来运算,SF的值则没有意义,虽然相关的指令影响了它的值。
检测点11.1
11.4 CF标志
flag的第0位是CF,进位标志位。一般情况下,在进行无符号运算的时候,它记录了运算结果的最高有效位向更高位的进位值,或从更高位的借位值。
对于位数为N的无符号数,其对应的二进制信息的最高位,即第N-1位,就是它的最高有效位,假想存在第N位是相对于最高有效位的更高位。
两个8位的数据运算可能产生进位或者借位,由于这个进位值在8位数中无法保存,8086CPU就用flag的CF位来记录这个进位值。
mov al.98h
add al,al ;执行后(al)=30H,cf=1,cf记录了从最高有效位向更高位的进位值
add al,al ;执行后(al)=60H,cf=0,cf记录了从最高有效位向更高位的进位值
mov al,97h
sub al,98h ;执行后(al)=ffh,cf=1,cf记录了向更高位的借位值
sub al,al ;执行后(al)=0,cf=0,cf记录了向更高位的借位值
11.5 OF标志
检测点11.2
11.6 abc指令
adc是带进位加法指令,利用了CF位上记录的进位值。
格式:adc 操作对象1,操作对象2
功能:操作对象1=操作对象1+操作对象2+CF。
mov ax,2
mov bx,1
sub bx,ax
adc ax,1