8086FLAG寄存器

Posted lcchuguo

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了8086FLAG寄存器相关的知识,希望对你有一定的参考价值。

         8086中的FLAG寄存器也就是状态标志位寄存器。它用来存储一些指令的计算结果,比如加法减法中的进位;为CPU运行某些命令提供根据,比如DF它决定是往前走指针还是向后走指针;总之状态寄存器存放的被称为程序状态字(PSW)。

         8086中的寄存器一共同拥有例如以下所看到的:

1      ZF(0标志)

指令的运行结果为0,就ZF=1,否则ZF为0。

MOV AX,  1

SUB  AX,   1;ZF = 1

MOV AX,  2

SUB AX,    1;ZF= 0

2      PF(奇偶标志)

结果中个1的个数为偶数则PF=1,否则PF = 0。

MOV AL,  1

ADD AL,   10;运行结果为:1011B。PF =0

MOV AL,  1

OR AL,      2;运行结果为:0011B,PF = 1

3       SF(符号标志位)

         运行指令后。假设结果为负,则SF=1。否则SF=0

         SF是针对有符号数来讲的,它记录数据的正负,当我们把数据当做带符号的时候,只SF来推断结果的正负

<1> 有无符号的区分

         汇编中的带符号数和无符号数:在汇编中事实上没有针对有无符号做出区分和标志,区不区分是人的主观看待的。比如:

MOV AX 1000 0001B

ADD AX,   1;

当我们把运算当做无符号数来计算的时候,1000 0001B = 129,129 + 1 = 130;130的二进制表示1000 0010B。

当我们把运算当做有符号数来计算的时候。1000 0001B = -127,-127 + 1 = -126.-126的补码是

1000 0010B。

可见无论怎么当做什么,最后的结构都表示都是一样的,仅仅只是是当做是无符号数的时候,你不必去把补码转换成原码,由于当做无符号数的时候,相当于给最高位前面加了1位。而且这位值是0;当做是符号位的时候,你自然要依据最后的补码再转换成原码了。

<2>  溢出的问题

关于符号位的计算,当我们计算加法的时候,最高位是符号位。问题是符号位參与运算没?

答案是參与了。补码的的范围不包括符号位,可是补码相加后会产生进位,进位会与符号位參与运算,运算结果决定了终于的符号位。

 

4      CF(进位标志)

这个是针对无符号的运算的。表示加法的进位以及减法的借位。

5      OF(溢出标志)

这个标志是针对符号位的,当进行有符号的运算的时候。假设计算的范围超过了规定的范围。那么就会产生溢出。

6       adc指令

Adc指令是加法指令,它和add类似,仅仅只是是把进位值也相加了。

利用adc指令能够非常方便的进行多进制数的叠加,仅仅须要開始的时候进位制设为0,然后就每次相加16位。就这样子非常easy。

7       sbb指令

带进位的减法。它的功能是:操作数1 – 操作数2 – 进位值(借位)

 

8       CMP指令

它运行的是:操作数1 – 操作数2;依据计算结果对寄存器进行设置,可是不保存结果。

可是不能只sf的值去推断结果去推断比較结果的大小。

由于sf是针对有符号的数字来说的,假设在进行计算的时候发生了溢出。就不能简简单单依据sf的值推断正负了,所以要依据溢出标志of和符号标志sf去综合推断。

如: 34 –(-96) = 130,这时候of=1。sf=1。不能说明34< -96

<1> sf = 1,of =0,说明A<B

<2>sf = 1,of = 1,说明A>B

<3>sf = 0,of = 0,说明A>B

<4>sf = 0,of = 1,说明A<B

 

9       依据比較结果的转移指令

运行cmp指令后。会影响zf,pf,sf。cf。of,依据这些值的大小会有对应的跳转指令。

Je,          zf =1,等于跳转

Jne。        zf=0,不等于跳转

Jb,          cf=1,低于跳转

Jnb,        cf=0,不低于跳转

Ja。          cf=0,且zf=0,高于则跳转

Jna。        cf=1活zf=1,不高于则跳转

 

10     DF(方向标志)

它的值决定每次运行后si。di的值是递增还是递减

有下面两个指令movsb,movsw。

<1>movsb

( (es)*16 + (di) ) = ( (ds)*16 +(si) )

假设df =0,(si) = (si) + 1,(di) = (di) + 1

假设df=1。(si) = (si) -1,(di) = (di) – 1

<2>movsw

( (es)*16 + (di) ) = ( (ds)*16 +(si) )

假设df =0,(si) = (si) + 2,(di) = (di) + 2

假设df=1。(si) = (si) -2,(di) = (di) – 2

<3>rep

这个表示反复的意思,有两种格式了

Rep movsb。

Rep movsw;

分别相当于:

S:movsb

Loop S;

S:movsw

Loop S;

<4>cld,std

Cld,将标志位的df置0。std。将标志位的df置1.

以下这个程序实现的是将ds中的字节的复制。

MOV AX,DATA

MOV DS,AX

MOV SI,0

MOV ES,AX

MOV DI,16

CLD

REP MOVSB

 

11     pushf和popf

这个是将标志寄存器中的各位压栈和出栈

 

以上是关于8086FLAG寄存器的主要内容,如果未能解决你的问题,请参考以下文章

8086汇编语言学习 8086标志寄存器

标志寄存器综述

第11章标志寄存器 其一

第11章标志寄存器 其一

汇编语言——标志寄存器

《汇编语言(第三版)》标志寄存器