汇编知识整理: 标志寄存器

本文详细介绍了8086CPU中的标志寄存器,包括各个标志位的作用,如零标志位ZF、奇偶标志位PF、符号标志位SF等,并解释了这些标志位如何影响指令执行。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

中文名:标志寄存器
英文名:Flag Register



8086CPU的标志(flag)寄存器的结构如图所示:

标志寄存器 - xintianyou_t - 信天游

ZF:零标志位。它记录相关指令执行后,其结果是否为0。如果结果为0,那么 zf = 1;如果结果不为0,那么 zf = 0。


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


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


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


OF:溢出标志位。一般情况下,它记录了有符号数运算的结果是否发生了溢出。如果发生溢出,of = 1;如果没有,of = 0。


DF:方向标志位。在串处理指令(movsb,movsw)中,控制每次操作后si、di的增减。df=0 每次操作后si,di递增;df=1 每次操作后si,di递减。

 

8086 CPU提供了两条指令对DF位进行设置

cld指令;将标志寄存器的df位设置为0  //正向传递

std指令;将标志寄存器的df位设置为1  //逆向传递

 

标志              值为1的标记      值为0的标记

of                       OV                       NV

sf                       NG                       PL

zf                       ZR                        NZ

pf                       PE                       PO

cf                       CY                       NC

df                       DN                       UP

标志寄存器 - xintianyou_t - 信天游


标志寄存器使用注意

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


标志寄存器CF和OF的区别

CF是对无符号数有意义的标志位,而OF是对有符号数有意义的标志位。

对于无符号数的运算,CPU用CF标志位来记录运算中是否产生了进位。

对于有符号数的运算,
CPU用OF标志位来记录运算中是否产生了溢出;另外,还需要SF标志位来记录结果的符号。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值