汇编语言个人学习笔记——第十一章 标志寄存器

引言:

8086CPU的标志寄存器有16位,其中存储的信息通常被称为程序状态字(PSW)。

我们已经使用过8086CPU的ax、bx、cx、dx、si、di、bp、sp、ip、cs、ss、ds、es等13个寄存器了。

标志寄存器(简称flag)是要学习的最后一个寄存器。

flag和其他寄存器不一样,其他寄存器是用来存放数据的,都是整个寄存器具有一个含义。

而flag寄存器是按位起作用的,也就是说,它的每一位都有专门的含义,记录特定的信息。

8086CPU的flag寄存器的结构:

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

 

11.1ZF标志

flag的第6位是ZF,零标志位。

它记录相关指令执行后,

结果为0,ZF=1

结果不为0,ZF=0

例如:

 mov ax,1

sub ax,1

指令执行后,结果为0,则ZF=1。

mov ax,2

mov ax,1

指令执行后,结果为1,则ZF=0。

对于ZF的值,我们可以这样来看,ZF标记相关指令的计算结果是否为0,如果为0,则在ZF要记录下“是0”这样的肯定信息。

指令:mov ax,1

           and ax,0

执行后,结果为0,则ZF=1,表示“结果是0”。

指令:mov ax,1

           or ax,0

执行后,结果不为0,则ZF=0,表示“结果非0”。

注意:

在8086CPU的指令集中,有的指令的执行是影响标志寄存器的,比如:add、sub、mul、div、inc、or、and等,它们大都是运算指令(进行逻辑或算术运算);

有的指令的执行对标志寄存器没有影响,比如:mov、push、pop等,它们大都是传送指令。

我们在使用一条指令的时候,要注意这条指令的全部功能,其中包括,执行结果对标志寄存器的哪些标志位造成影响。

 

11.2PF标志

flag的第2位是PF,奇偶标志位。

它记录指令执行后,结果的所有二进制位中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;

 

 

11.3SF标志

flag的第7位是SF,符号标志位。

它记录指令执行后,

结果为负,SF=1;

结果为正,SF=0。

有符号数与补码

我们知道计算机中通常用补码来表示有符号数据。计算机中的一个数据可以看作是有符号数,也可以看作是无符号数。

比如:

00000001B,可以看作无符号数1,或有符号数+1;

10000001B,可以看作无符号数129,也可以看作有符号数-127。

这也就是说,对于同一个二进制数据,计算机可以将它当作无符号数据来运算,也可以当作有符号数据来运算。

示例

mov al,10000001B

add al,1

结果:(al)=10000010B

我们可以将add指令进行的运算当作无符号数的运算,那么add指令相当于计算129+1,结果为130

(10000010B);

也可以将add指令进行的运算当作有符号数的运算,那么add指令相当于计算-127+1,结果为-126

(10000010B)。

不管我们如何看待,CPU在执行add等指令的时候,就已经包含了两种含义,也将de'd得到用同一种信息来记录的lian两种结果。

关键在于我们的程序需要哪一种结果。

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

在我们将数据当作有符号数来运算的时候,可以通过SF来得知结果的正负。

如果我们将数据当作无符号数来运算,SF的值则没有意义,虽然相关的指令影响了它的值。

这也就是说,CPU在执行add等指令时,是必然要影响到SF标志位的值的。

至于我们需不需要这种影响,就要看我们如何看待指令所进行的运算了。

示例1:

mov al,10000001B

add al,1

执行后,结果为10000010B,SF=1,

表示:如果指令进行的是有符号数运算,那么结果为负;

示例2:

mov al,10000001B

add al,01111111B

执行后结果为0,SF=0

表示:如果指令进行的是有符号数运算,那么结果为非负。

某些指令将影响标志寄存器中的多个标志位,这些被影响的标记位比较全面地记录了指令地执行结果,为相关的处理提供了所需的依据。

比如指令sub al,al执行后,ZF、PF、SF等标志位都要受到影响它们分别位1、1、0。

 

11.4CF标志

flag的第0位是CF,进位标志位。

一般情况下,在进行无符号数运算的时候

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值