汇编语言--微机CPU的指令系统(五)(比较运算指令)

(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)

后面学习中介绍

猜你喜欢

转载自www.cnblogs.com/CIreland/p/9961567.html