-----------------------算数运算指令-----------------------
ADD          加法
ADC          带位加法
SBB           带位减法
SUB          减法.
INC          加法.
NEC          求反(以0减之).
NEG          求反然后加1,假如NEG AL相当于Not AL; INC AL
CMP          比较.(两操作数作减法,仅修改标志位,不回送结果).
INC DPTR     数据指针寄存器值加1 (说明:将16位的DPTR加1,当DPTR的低字节(DPL)从FFH溢出至00H时,会使高字
节(DPH)加1,不影响任何标志位)

MUL A B     将累加器的值与B寄存器的值相乘,乘积的低位字节存回累加器,高位字节存回B寄存器(说明:将累加
器A和寄存器B内的无符号整数相乘,产生16位的积,低位字节存入A,高位字节存入B寄存器.如果积大于FFH,则溢出

标志位(OV)被设定为1,而进位标志位为0)

IMUL        整数乘法. 以上两条,结果回送AH和AL(字节运算),或DX和AX(字运算),
DIV A B     将累加器的值除以B寄存器的值,结果的商存回累加器,余数存回B寄存器(说明:无符号的除法运算,
将累加器A除以B寄存器的值,商存入A,余数存入B。执行本指令后,进位位(C)及溢出位(OV)被清除为0)

IDIV    整数除法. 以上两条,结果回送: 商回送AL,余数回送AH, (字节运算);  或  商回送AX,余数回送DX, (字运

算).

 AAA    加法的ASCII码调整.
 DAA    加法的十进制调整.
 AAS    减法的ASCII码调整.
 DAS    减法的十进制调整.
 AAM    乘法的ASCII码调整.
 AAD    除法的ASCII码调整.
 CBW   字节转换为字. (把AL中字节的符号扩展到AH中去)
 CWD   字转换为双字. (把AX中的字的符号扩展到DX中去)
 CWDE  字转换为双字. (把AX中的字符号扩展到EAX中去)
 CDQ   双字扩展.     (把EAX中的字的符号扩展到EDX中去)

-----------------------逻辑运算指令---------------------------------
AND    与运算.
OR      或运算.
XOR    异或运算.
NOT    取反.
TEST    测试.(两操作数作与运算,仅修改标志位,不回送结果).
SHL    逻辑左移.
SHR    逻辑右移.  
SAL    算术左移.(=SHL)
SAR    算术右移. (左移是一样的,右移是不同的.逻辑右移补0,算术右移补最高位)   
ROL    循环左移.  ( ((unsigned char)a) << 5 ) | ( ((unsigned char)a) >> 3 )
                  rol eax,cl ==> eax=(eax<<cl)+(eax>>(32-cl));
ROR    循环右移.  ror eax,cl ==> eax=(eax>>cl)+(eax<<(32-cl));
RCL    通过进位的循环左移.
RCR    通过进位的循环右移.
以上八种移位指令,其移位次数可达255次.
    移位一次时, 可直接用操作码.  如 SHL AX,1.
    移位>1次时, 则由寄存器CL给出移位次数.
        如  MOV CL,04
        SHL AX,CL

-----------------------数据转移指令---------------------------------

1. 通用数据传送指令.
    MOV    传送字或字节.
    MOVSX  先符号扩展,再传送.
    MOVZX  先零扩展,再传送.
    PUSH    把字压入堆栈.
    POP    把字弹出堆栈.
    PUSHA  把AX,CX,DX,BX,SP,BP,SI,DI依次压入堆栈.
    POPA    把DI,SI,BP,SP,BX,DX,CX,AX依次弹出堆栈.
    PUSHAD  把EAX,ECX,EDX,EBX,ESP,EBP,ESI,EDI依次压入堆栈.
    POPAD  把EDI,ESI,EBP,ESP,EBX,EDX,ECX,EAX依次弹出堆栈.
    BSWAP  交换32位寄存器里字节的顺序
    XCHG    交换字或字节.( 至少有一个操作数为寄存器,段寄存器不可作为操作数)
    CMPXCHG 比较并交换操作数.( 第二个操作数必须为累加器AL/AX/EAX )
    XADD    先交换再累加.( 结果在第一个操作数里 )
    XLAT    字节查表转换.
        ── BX 指向一张 256 字节的表的起点, AL 为表的索引值 (0-255,即 0-FFH); 返回 AL         

       为查表结果. ( [BX+AL]->AL )
2. 输入输出端口传送指令.
    IN      I/O端口输入. ( 语法: IN 累加器, {端口号│DX} )
    OUT    I/O端口输出. ( 语法: OUT {端口号│DX},累加器 )
        输入输出端口由立即方式指定时, 其范围是 0-255; 由寄存器 DX 指定时,
        其范围是 0-65535.
----------------------- 目的地址传送指令-----------------------
LEA    装入有效地址.  例: LEA DX,string  ;把偏移地址存到DX.
LDS    传送目标指针,把指针内容装入DS. 例: LDS SI,string  ;把段地址:偏移地址存到DS:SI.
LES    传送目标指针,把指针内容装入ES. 例: LES DI,string  ;把段地址:偏移地址存到ES:DI.
LFS    传送目标指针,把指针内容装入FS. 例: LFS DI,string  ;把段地址:偏移地址存到FS:DI.
LGS    传送目标指针,把指针内容装入GS. 例: LGS DI,string  ;把段地址:偏移地址存到GS:DI.
LSS    传送目标指针,把指针内容装入SS. 例: LSS DI,string  ;把段地址:偏移地址存到SS:DI.

----------------------- 标志传送指令-----------------------

LAHF    标志寄存器传送,把标志装入AH.
SAHF    标志寄存器传送,把AH内容装入标志寄存器.
PUSHF   标志入栈.
POPF    标志出栈.
PUSHD   32位标志入栈.
POPD    32位标志出栈.
0012F618  |00A8E5A8  ASCII "nk'MHBh30"


-----------------------程序转移指令 -----------------------

1>无条件转移指令 (长转移)
    JMP    无条件转移指令
    CALL    过程调用
    RET/RETF过程返回.
2>条件转移指令 (短转移,-128到+127的距离内)
    ( 当且仅当(SF XOR OF)=1时,OP1<OP2 )
    JA/JNBE 不小于或不等于时转移.
    JAE/JNB 大于或等于转移.
    JB/JNAE 小于转移.
    JBE/JNA 小于或等于转移.
        以上四条,测试无符号整数运算的结果(标志C和Z).
    JG/JNLE 大于转移.
    JGE/JNL 大于或等于转移.
    JL/JNGE 小于转移.
    JLE/JNG 小于或等于转移.
        以上四条,测试带符号整数运算的结果(标志S,O和Z).
    JE/JZ  等于转移.
    JNE/JNZ 不等于时转移.
    JC      有进位时转移.
    JNC    无进位时转移.
    JNO    不溢出时转移.
    JNP/JPO 奇偶性为奇数时转移.
    JNS    符号位为 "0" 时转移.
    JO      溢出转移.
    JP/JPE  奇偶性为偶数时转移.
    JS      符号位为 "1" 时转移.
3>循环控制指令(短转移)
    LOOP            CX不为零时循环.
    LOOPE/LOOPZ    CX不为零且标志Z=1时循环.
    LOOPNE/LOOPNZ  CX不为零且标志Z=0时循环.
    JCXZ            CX为零时转移.
    JECXZ          ECX为零时转移.
4>中断指令
    INT    中断指令
    INTO    溢出中断
    IRET    中断返回
5>处理器控制指令
    HLT    处理器暂停, 直到出现中断或复位信号才继续.
    WAIT    当芯片引线TEST为高电平时使CPU进入等待状态.
    ESC    转换到外处理器.
    LOCK    封锁总线.
    NOP    空操作.
    STC    置进位标志位.
    CLC    清进位标志位.
    CMC    进位标志取反.
    STD    置方向标志位.
    CLD    清方向标志位.
    STI    置中断允许位.
    CLI    清中断允许位.

-----------------------串指令-----------------------

DS:SI   源串段寄存器  :串变址.
ES:DI   目标串段寄存器:串变址.
CX      重复次数计数器.
AL/AX   扫描值.
D标志   0表示重复操作中SI和DI应自动增量; 1表示应自动减量.
Z标志   用来控制扫描或比较操作的结束.
cld  将DF置为0
std  将DF置为1
MOVS    串传送.
    ( MOVSB  传送字符。将ds:si指向的内存单元中的字节送入es:di中,然后根据DF的标志将si和di的值增或减(0增1减)
      MOVSW  传送字。  将ds:si指向的内存单元中的字节送入es:di中,然后根据DF的标志将si和di的值增或减(0增1减)
      MOVSD  传送双字. ) 经常这么用rep movsb相当于s:movsb ; loop s

CMPS    串比较.
    ( CMPSB  比较字符.    CMPSW  比较字. )
SCAS    串扫描. 把AL或AX的内容与目标串作比较,比较结果反映在标志位.
LODS    装入串. 把源串中的元素(字或字节)逐一装入AL或AX中.
    ( LODSB  传送字符.    LODSW  传送字.    LODSD  传送双字. )
STOS    保存串.是LODS的逆过程.
REP            当CX/ECX<>0时重复.
REPE/REPZ      当ZF=1或比较结果相等,且CX/ECX<>0时重复.
REPNE/REPNZ    当ZF=0或比较结果不相等,且CX/ECX<>0时重复.
REPC           当CF=1且CX/ECX<>0时重复.
REPNC          当CF=0且CX/ECX<>0时重复.

-----------------------伪指令-----------------------
DW      定义字(2字节).
PROC    定义过程.
ENDP    过程结束.
SEGMENT 定义段.
ASSUME  建立段寄存器寻址.
ENDS    段结束.
END    程序结束.  
posted on 2009-07-13 17:24  on_road  阅读(10595)  评论(0编辑  收藏  举报