目录 上一页 下一页 下一章

第2章 开始设计程序 -25-

    DEC 内存单元
执 行:原数据减1,结果仍保存于这个寄存器或内存单元中
  这条指令和C语言的那个"--"运算符一样。由于所有段寄存器都不参与运算,所以没有"DEC DS"这样的用法。
  在程序PROG2-B中我们一开始用BX来保存外循环的计数值,在内循环执行完后,我们用"DEC BX"使得BX中的计数值减1。下面的问题就是看BX是否被减成0。这由新增的JNZ指令完成。
助记符:JNZ(JUMP IF NOT ZERO)
用 途:根据运算结果是否非0来控制转移
格 式:JNZ 目的地址
执 行:若ZF=0,则转移至目的地址执行指令;若ZF=1,则继续执行下面的指令
  新的问题出现了,ZF是什么?是新的寄存器吗?
  这个问题不会再留到后面讨论了,因为它本身就是个遗留下来的问题。请看第一节内"细看PC机"中的2.2.5,在前文我们刚刚讨论了堆栈指针(SP)寄存器,还留了3个小问题,现在我们就来讨论"标志寄存器"。
  对于一般数学运算我们不仅要关心运算的结果,同时要关心"运算后果"。以"DEC BX"为例,若BX〉1,则执行一次DEC指令不会使BX减为0,即运算没有造成变量变成0的"后果";若BX=1,则执行一次DEC即可造成"BX=0"的后果。因此对于DEC指令而言,它可以造成两种不同的后果:
  (1)被减的变量仍大于0;    (2)被减的变量恰好成了0。
  我们所编的程序并不关心"DEC BX"的结果是什么,但是要关心"DEC BX"的后果。因为BX被减至0实际意味着外循环的结束。那么运算的后果记录在什么地方呢?
  在CPU中有一个特殊的16bit寄存器,此寄存器称为"标志寄存器(FLAG Register)"。和通用寄存器、段寄存器不同,它并不用于保存数据,CPU用它某些位的0,1状态来记录运算的后果。它的结构如图2-7所示。

图2-7 标志寄存器的结构
  所用到的各个位的解释都列在表2-1中,其中的ZF位就是我们现在所关心的。ZF被称为"零标志位"(Zero Flag),当某次运算的结果恰好是0时,ZF将被"置位(SET)",即ZF=1;否则ZF"复位(RESET)"。JNZ指令根据ZF的状态来转移。
表2-1 标志寄存器各个位的功能表
标志位功 能 解 释清0置1
CF进位(借位)标志,某次运算有进位或借位时此标志置1NCCY
PF奇偶标志,若运算结果中为1的位有偶数个此标志置1PEPO
AF辅助进位标志*,记录运算中低4位向高4位或低8位向高8位的进位ACNA
ZF零标志,若运算结果等于0此标志置1ZRNZ
SF符号标志,运算结果为负数此标志置1NGPL
TF陷井标志,当此标志位置1后CPU处于单步执行方式--
IF中断标志,此标志置1时允许CPU响应中断,置0时将屏蔽中断**EIDI
DF方向标志,用于控制串处理指令的步进方向DNUP
OF溢出标志,若运算发生溢出时此标志置1OVNV
注:* 也称为半进位标志; ** 对不可屏蔽中断(NMI)没有影响

Copyright © 2004-2015 Reanimator www.cookmoon.org

目录 上一页 下一页 下一章