zoukankan      html  css  js  c++  java
  • 汇编语言--微机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)

    后面学习中介绍

  • 相关阅读:
    codeforces 690C3 C3. Brain Network (hard)(lca)
    codeforces 690C2 C2. Brain Network (medium)(bfs+树的直径)
    codeforces 690C1 C1. Brain Network (easy)(水题)
    codeforces 459E E. Pashmak and Graph(dp+sort)
    bzoj-1296[SCOI2009]粉刷匠(dp)
    codeforces 689E E. Mike and Geometry Problem(组合数学)
    Useful Field of View (UFOV)
    mongodb基础
    node.excel
    犀牛-6对象
  • 原文地址:https://www.cnblogs.com/CIreland/p/9961567.html
Copyright © 2011-2022 走看看