(7)比较运算指令
在程序中,我们要时常根据某个变量或表达式的取值去执行不同指令,从而使程序表现出有不同的功能。为了配合这样的操作,在CPU的指令系统中提供了各种不同的比较指令。通过这些比较指令的执行来改变有关标志位,为进行条件转移提供依据。
1、比较指令CMP(Compare Instruction)
指令的格式:CMP Reg/Mem, Reg/Mem/Imm
受影响的标志位:AF、CF、OF、PF、SF和ZF
指令的功能:用第二个操作数去减第一个操作数,并根据所得的差设置有关标志位,为随后的条件转移指令提供条件。但并不保存该差,所以,不会改变指令中的操作数。
2、比较交换指令(Compare And Exchange Instruction)
在数据传送类指令中,我们介绍了交换指令XCHG,它不管二个操作数的值是什么,都无条件地进行交换。而比较交换指令,是先进行比较,再根据比较的结果决定是否进行操作数的交换操作。
比较交换指令的功能:当二个操作数相等时,置标志位ZF为1;否则,把第一操作数的值赋给第二操作数,并置标志位ZF为0。
a) 8位/16位/32位比较交换指令
指令的格式:CMPXCHG Reg/Mem, AL/AX/EAX ;80486+
受影响的标志位:AF、CF、OF、PF、SF和ZF
b) 64位比较交换指令
该指令只有一个操作数,第二个操作数EDX:EAX是隐含的。
指令的格式:CMPXCHG8B Reg/Mem ;Pentium+
受影响的标志位:ZF
例如:假设(AX)=1234H,(BX)=1234H,(CX)=4321H。
CMPXCHG BX, AX ;指令执行后,ZF=1
CMPXCHG CX, AX ;指令执行后,ZF=0,(AX)=4321H,CX的值不变
3、字符串比较指令(Compare String Instruction)
后面学习中介绍