标志寄存器


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

  • 用来存储相关指令的某些执行结果
  • 用来为CPU执行相关指令提供行为依据
  • 用来控制CPU的相关工作方式
    这种特殊的寄存器在8086CPU中,被称为标准寄存器,8086CPU的标志寄存器有16位,其中存储的信息通常被称为程序状态字
    标志寄存器(flag)和其他寄存器不一样,其他寄存器是用来存放数据的,都是整个寄存器具有一个含义。而flag寄存器是按位起作用的,8086CPU的flag寄存器的结构如图所示:
    在这里插入图片描述

ZF标志

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

mov ax,1
sub ax,1

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

mov ax,2
sub ax,1

执行后,结果不为0,则zf=0
注意,在8086CPU的指令集中,有的指令的执行是影响标志寄存器的,比如,add,sub,mul,div,inc,or,and等,它们大都运算指令,有的指令的执行对标志寄存器没有影响,比如,mov,push,pop等,它们大都是传送指令,在使用一条指令的时候,要注意这条指令的全部功能,其中包括,执行结果对标志寄存器的哪些标志位造成影响。

PF标志

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

mov al,1
add al,10

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

mov al,1
or al,2

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

SF标志

flag的第7位是SF,符号标志位,它记录相关指令执行后,其结果是否为负,如果结果为负,sf=1,如果非负,sf=0
计算机中通常用补码来表示有符号数据,计算机中的一个数据可以看作是有符号数,也可以看成是无符号数,比如:

  • 00000001B,可以看作为无符号数1,或有符号数+1
  • 10000001B,可以看作为无符号数129,也可以看作有符号数-127
    SF标志,就是CPU对有符号数运算结果的一种记录,它记录数据的正负,在外面将数据当作有符号数来运算的时候,可以通过它来得知结果的正负,如果我们将数据当作无符号来运算,SF的值则没有意义,,虽然相关的指令影响了它的值

CF标志

flag的第0位是CF,进位标志位,一般情况下,在进行无符号数运算的时候,它记录了运算结果的最高有效位向更高位的进位值,或从更高位的借位值。
对于位数为N的无符号数来说,其对应的二进制信息的最高位,即第N-1位,就是它的最高有效位,而假想存在的第N位,就是相对于最高有效位的更高位,如图所示:
在这里插入图片描述
我们知道,当两个数据相加的时候,有可能产生从最高有效位向更高位的进位,比如,两个8位数据:98H+98H,将产生进位,由于这个进位值在8位数中无法保存,我们在之前只是简单的说这个进位值丢失了,其实CPU在运算的时候,并不会丢弃这个进位值,而是记录在一个特殊的寄存器的某一位上,8086CPU就用flag的CF位来记录这个进位值,比如下面的指令:

mov al,98H
add al,al//执行后:(al)=30H,CF=1,CF记录了从最高有效位向更高位的进位值
add al,al//执行后,(al)=60H,CF=0,CF记录了从最高有效位向更高位的进位值

当两个数据做减法的时候,有可能向更高位借位,比如,两个8位数据:97H-98H,将产生借位,借位后,相当于计算197H-98H,而flag的CF位也用来记录这个借位值。

OF标志

在进行有符号数运算的时候,如结果超过了机器所能表示的范围称为溢出
什么是机器所能表示的范围?
比如说,指令运算的结果用8位寄存器或内存单元来存放,那么对于8位的有符号数据,机器所能表示的范围是-128-127,同理,对于16位有符号数据,机器所能表示的范围是-32768-32767
如果运算结果超出了机器所能表达的范围,将产生溢出
flag的第11位是OF,溢出标志位,一般情况下,OF记录了有符号数运算的结果是否发生了溢出,如果发生了溢出,OF=1,如果没有,OF=0
一定要注意CF和OF的区别:CF是对无符号数运算有意义的标志位,而OF是对有符号运算有意义的标志位,比如:

mov al,98
mov al,99

add指令执行后:CF=0,OF=1,CPU在执行add等指令的时候,就包含了两种含义:无符号位数运算和有符号未运算,对于无符号数运算,CPU用CF位来记录是否产生了进位,对于有符号位运算,CPU用OF位来记录是否产生了溢出,当然还要用SF位来记录结果的符号,对于无符号数运算,98+99没有进位,CF=0,对于有符号数运算,99+98发生了溢出,OF=1
我们可以看到,CF和OF所表示的进位和溢出,是分别对无符号数和有符号数运算而言的,它们之间没有任何关系

  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值