标志寄存器df_标志寄存器

本文详细介绍了8086CPU的标志寄存器,包括其作用、大小、各位的特殊含义,如零标志位(ZF)、奇偶标志位(PF)、符号标志位(SF)、进位标志位(CF)和溢出标志位(OF),并解释了如何通过这些标志位来判断运算结果。同时提到了DF标志位在串处理指令中的作用,以及如何通过cld和std指令设置其方向。文章还讨论了adc和sbb指令在处理大数值运算中的应用,以及cmp指令的比较功能和对标志寄存器的影响。
摘要由CSDN通过智能技术生成

标志寄存器(8086CPU)

作用

用来存储相关指令的某些执行结果

用来为CPU执行相关指令提供行为依据

用来控制CPU的相关工作方式

大小

标志寄存器有16位

使用方式

标志寄存器是按位起作用,也就是说每一个位都有专门的含义,记录特定的i西南西

9c72af03f3dc377c43cc80df94b7666c.png

flag的1、3、5、12、13、14、15位在8086CPU中没有使用,不具有任何含义。而0、2、4、6、7、8、9、10、11位都具有特殊的含义

ZF标志,在第6位,结果为0则为1,否则为0

zf (Zero Flag) 是零标志位,在第6位;它记录相关指令执行后,其结果是否为0,如果为0,那么zf = 1;否则zf = 0

例如

mov ax, 1

sum ax, 1

执行后, 结果为0,则zf = 1

mov ax, 2

sum ax, 1

执行后,结果不为0,则zf = 0

注意

在指令执行的过程中,有些指令对标志寄存器有影响,比如:add、sum、mul、div、inc、or、and等,他们大都是运算指令;而有些指令对标志寄存器没有影响,比如:mov、push、pop等,他们大都是传送指令。在使用一条指令的时候,要注意这条指令的全部功能,其中包括,执行结果对标志寄存器的哪些标志位产生了影响。

PF标志,在第2位,结果中1的个数为偶数则为1,否则为0

pf( Parity Flag)表示奇偶标志位,在第2位;他记录的是相关指令执行后,如果所有的bit位中1的个数是否为偶数。如果1的个数位偶数,pf = 1,如果为奇数,那么pf = 0

例如:

mov al, 1

add al, 10

执行后结果为1011B,其中有3(奇数)个1,则pf = 0

mov al, 1

or al, 2

执行后,结果为:11B,其中有2(偶数)个1,则pf = 1

SF 标志,在第7位,结果为负则为1,否则为0;有符号运算有效

sf(Symbol Flag)表示符号标志位,在第7位;它记录相关指令执行后,其结果是否为负。如果为负,则sf = 1;如果非负,sf = 0

通常CPU计算的时候有两种方式,一种是有符号的计算,一种是无符号的计算。

SF标志,就是CPU对有符号数运算结果的一种记录,他记录数据的正负。

如果我们将数据进行无符号运算ÿ

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值