1、汇编指令全集 ZZ以下是 80X86 汇编过程中经常用到的一些汇编指令。从功能分类上来说,一共可分为一、 数据传送指令:MOV、XCHG 、LEA、LDS 、LES 、PUSH、POP 、PUSHF、POPF、CBW、CWD 、CWDE 。二、 算术指令:ADD、ADC、INC 、SUB、SBB、DEC、CMP 、 MUL、DIV 、DAA 、DAS、AAA、AAS。三、 逻辑指令:AND、OR、XOR、NOT、TEST、SHL、SAL、SHR 、SAR 、RCL、RCR、 ROL、ROR。四、 控制转移指令:JMP、Jcc、JCXZ、LOOP、LOOPZ、LOOPNZ、LOOPNE、CALL
2、、RET、INT。五、 串操作指令:MOVS、LODS 、STOS、CMPS 、SCAS。六、 标志处理指令:CLC、STC、CLD 、STD。七、 32 位 CPU 新增指令-数据传送指令-1、 MOV(传送)指令写法:MOV target,source功能描述:将源操作数 source 的值复制到 target 中去,source值不变注意事项:1)target 不能是 CS(代码段寄存器),我的理解是代码段不可写,只可读,所以相应这地方也不能对 CS 执行复制操作。2)target 和 source 不能同时为内存数、段寄存器(CSDSESSSFSGS)3)不能将立即数传送给段寄存器 4
3、)target 和 source 必须类型匹配,比如,要么都是字节,要么都是字或者都是双字等。4)由于立即数没有明确的类型,所以将立即数传送到 target 时,系统会自动将立即数零扩展到与 target数的位数相同,再进行传送。有时,需要用 BYTE PTR 、WORD PTR、 DWORD PTR 明确指出立即数的位数写法示例:MOV dl,01H;MOV eax,bp; eax =ss:bp 双字传送。2、 XCHG(交换)指令写法:XCHG object1,object2功能描述:交换 object1 与 object2 的值注意事项:1)不能直接交换两个内存数的值 2 )类型必须匹配
4、3)两个操作数任何一个都不能是段寄存器【看来段寄存器的写入的限制非常的严格,MOV 指令也不能对段寄存器进行写入 】,4)必须是通用寄存器( ax、bx、cx、dx 、si、di)或内存数写法示例:XCHG ax,bxsi; XCHG ax,bx;3、 LEA( 装入有效地址)指令写法:LEZ reg16,mem功能描述:将有效地址 MEM 的值装入到 16 位的通用寄存器中。写法示例:假定 bx=5678H,EAX=1,EDX=2Lea si,2bx ;si=567AHLea di,2eaxedx ;di=5注意,这里装入的是有效地址,并不是实际的内存中的数值,如果要想取内存中该地址对应的数
5、值,还需要加上段地址才行,而段地址有可能保存在 DS 中,也有可能保存在 SS 或者 CS 中哦:不知道我的理解可正确。4、 LDSLESLGSLSS(注意,与 LEA 不同的是,这里是装入的值,而不是有效地址)这几个指令,名称不同,作用差不多。写法:LDS reg16,mem32 功能描述:reg16 等于 mem32 的低字,而 DS 对应于 mem32 的高字(当为 LES 时,这里就是 ES 对应于 mem32 的高字)用来给一个段寄存器和一个 16 位通用寄存器同时复制。注意事项:第一个操作数必须是 16 位通用寄存器在接着往下说之前,先熟悉下堆栈的概念。堆栈,位于内存的堆栈段中,是
6、内存的一部分,具有“先进后出”的特点,堆栈只有一个入口,即当前栈顶,当堆栈为空时,栈顶和栈底指向同一内存地址,在 WINDOWS 中,可以把堆栈理解成一个倒着的啤酒瓶,上面的地址大,下面的地址小,当从瓶口往啤酒瓶塞啤酒时(进栈),栈顶就会往瓶口下移动,也就是往低地址方向移动,同理,出栈时,正好相反,把啤酒给倒出来,栈顶向高地址方向移动。这就是所谓的堆栈 ,哼哼,很 Easy 吧。在汇编语言中,堆栈操作的最小单位是字,也就是说,只能以字或双字为单位,同时,SS:SP 指向栈顶(SS 为堆栈段寄存器,SP 为堆栈指针,二者一相加,就构成了堆栈栈顶的内存地址)。5、 PUSH(进栈)写法:PUSH
7、reg16(32)/seg/mem16(32)/imm功能描述:将通用寄存器/段寄存器/内存数/立即数的值压入栈中,即:SP=SP-2 SS:SP=16 位数值(当将 32 位数值压入栈中时,SP=SP-4,SS:SP=32 为数值)6、 POP(出栈)写法:POP reg16(32)/seg/mem16(32)【不能出栈到 CS 中】功能描述:将堆栈口的 16(32)位数据推出到通用寄存器/段寄存器/内存中,即:寄存器/段寄存器/内存= SS:SP SP=SP+2(当将 32 位数值出栈时,SP=SP+4)(注意,不能出栈给立即数哦,常量不可变嘛)7、 PUSHA、PUSHAD、POPA、P
8、OPAD作用:将所有 16/32 位通用寄存器进栈/出栈如:PUSHA ;将 AX、CX、DX、BX、原 SP、BP、SI、DI 依次进栈。POPA 出栈顺序正好相反,但要注意的是,弹出到 SP 的值被丢弃,SP 通过增加 16 位来恢复(当然嘛,不然栈顶地址就被修改了,就会出息不对齐的情况,就有可能乱套了)POPAD PUSHAD 一样,只不过是 32 位的罢了。8、 PUSHF、PUSHFD、POPF、POPFD功能描述:标志寄存器 FLAGS(EFLAGS)进栈或出栈如:PUSHF ;FLAGS 进栈 POPF; 栈顶字出栈到 FLAGS总结下,POP 和 PUSH 通常可以用来交换两个
9、寄存器的值,也可以用来保护寄存器的值,如下:交换 ax 与 cx 的值:push ax;push cx;pop ax; pop cx;保护寄存器:push ax;push cx;.中间有很多执行的代码pop cx;pop ax;9、LAHFSAHF(标志寄存器传送指令)写法:lahf;作用:AH=FLAGS 的低 8 位写法:sahf;作用:FLAGS 的低 8 位=AH10、符号扩展和零扩展指令CBW;AL 符号扩展为 AXCWD;AX 符号扩展为 32 位数 DX:AXCWDE;AX 符号扩展为 EAX;CDQ:EAX 符号扩展为 64 位数 EDX:EAXMOVSX(符号扩展指令的一般形
10、式)写法:MOVSX reg1632,reg8reg16mem8mem16作用:用来将 8 位符号扩展到 16 位,或者 16 位符号扩展到 32 位MOVZX(零扩展指令)写法:MOVZX reg1632,reg8reg16mem8mem16零扩展,就是高位补 0 进行扩展。通常用在将数据复制到一个不同的寄存器中,如 AL 零扩展为 EBX。相同寄存器的零扩展,可以使用 MOV 高位, 0 来实现。11、BSWAP(字节交换)写法:bswap reg32作用:将 reg32 的第 0 与第 3 个字节,第 1 与第 2 个字节进行交换。示例:设 EAX=12345678h执行 bswap e
11、ax;后,eax=78563412H12、XLAT(换码)写法:XLAT;作用:AL=DS:bx+AL将 DS:BX 所指内存中的由 AL 指定位移处的一个字节赋值给 AL。(貌似这是一个方便偷懒的指令哦。),原来它的主要用途是查表。注意可以给它提供操作数,用来指定使用哪个段地址,如:XLAT ES:table;使用 ES 来作为段地址,table 不起作用。XLAT table ;使用 table 所在段对应的段寄存器作为段地址。-数据传送指令结束-算术指令开始-13、ADD(加法)写法:ADD reg/mem reg/mem/imm作用:将后面的操作数加到前面的操作数中注意:两个操作数必须
12、类型匹配,并且不能同时是内存操作数ADC (带进位加法)写法:ADC reg/mem, reg/mem/imm ;作用:dest=dest+src+cf当 CF=0 时 ADD 与 ADC 的作用是相同的。示例:实现 64 位数 EDX:EAX 与 ECX:EBX 的加法:Add EAX,EBX;ADC EDX,ECX;14、INC(自加一)写法:INC reg/mem;作用:dest=dest+1;15、XADD(交换加)写法:XADD reg/mem, reg作用:先将两个数交换,然将二者之和送给第一个数16、SUB(减法)写法:SUB reg/mem, reg/mem/imm;作用:de
13、st=dest-src;SBB(带借位减法)写法:SBB reg/mem, reg/mem/imm作用:dest=dest-src-cf;注意:两个操作数必须类型匹配,且不能同时是内存数17、DEC(自减 1)写法:DEC reg/mem;作用:dest=dest-1;18、CMP(比较)写法:CMP reg/mem, reg/mem/imm作用:dest-src注意:这里并不将结果存入 dest 中,而仅仅是执行相减的运算,达到依据运算结果去影响 EFLAG 标志位的效果19、NEG(求补)写法:NEG reg/mem作用:求补就是求相反数,即:dest=0-dest;20、CMPXCHG(
14、比较交换)写法:CMPXCHG reg/mem, reg;作用:AL/AX/EAX-oprd1,如果等于 0,则 oprd1=oprd2,否则,AL/AX/EAX=oprd1;即:比较 AL/AX/EAX 与第一个操作数,如果相等,则置 ZF=1,并复制第二个操作数给第一个操作数;否则,置 ZF=0,并复制第一个操作数给 AL/AX/EAX。说明:CMPXCHG 主要为实现原子操作提供支持CMPXCHG8B(8 字节比较交换指令)写法:CMPXCHG8B MEM64;功能:将 EDX:EAX 中的 64 位数与内存的 64 位数进行比较,如果相等,则置 ZF=1,并存储 ECX:EBX 到 m
15、em64 指定的内存地址;否则,置ZF=0,并设置 EDX:EAX 为 mem64 的 8 字节内容21、MUL(无符号乘法)写法:MUL reg/mem;作用:当操作数为 8 位时,AX=AL*src;当操作数为 16 位时,DX:AX=AX*src;当操作数为 32 位时,EDX:EAX=EAX*src;22、IMUL(带符号位乘法)写法:IMUL reg/mem;(作用同上)IMUL reg16,reg16/mem16,imm16;IMUL reg32,reg32/mem32,imm32;IMUL reg16,imm16/reg16/imm16;IMUL reg32,reg32/mem3
16、2/imm32;注意:没有两个操作数均为 8 位的多操作数乘法。对于同一个二进制数,采用 MUL 和 IMUL 执行的结果可能不同,设AL=0FF,BL=1,分别执行下面的指令,会得到不同的结果:Mul bl; AX=0FFH(255);Imul bl; AX=0FFFFH(-1)(高一半为低一半的扩展)23、DIV(无符号除法 )/IDIV(带符号数除法)写法:DIV reg/mem;/IDIC reg/mem作用:如果操作数是 8 位,AX%SRC,结果商在 AL、余数在 AH 中;如果操作数是 16 位,DX:AX%SRC,结果商在 AX,余数在 DX 中;如果操作数是 32 位,EDX
17、:EAX%SRC,结果商在 EAX,余数在 EDX 中;注意:不能直接实现 8 位数除 8 位数、16 位数除 16 位数、32 除32,若需要这样,则必须先把除数符号扩展或零扩展到 16、32、64位,然后用除法指令。对于 IDIV,余数和被除数符号相同,如:-5 IDIV 2 = 商 -2,余数:-1;在下列情况下,会使 CPU 产生中断:一:除数为 0 ;二:由于商太大,导致 EAXAX 或 AL 不能容纳,从而产生了溢出。-BCD 码调整指令(十进制调整指令)待补充-24、关于 BCD 码:BCD 码就是一种十进制数的二进制编码表示,分为压缩 BCD 码和非压缩BCD 码,压缩 BCD
18、 码用 4 个二进制位表示一个十进制位,即用 0000B1001B 表示十进制09,如 0110 0100 0010 1001B 表示 6429用 8 位二进制来表示一个十进制叫非压缩 BCD 码,其中,低四位与压缩 BCD 码相同,高四位无意义。压缩 BCD 码调整指令包括 DAA(加法的压缩 BCD 码调整)和 DAS(减法的压缩 BCD 码调整)写法:DAA;作用:调整 AL 中的和为压缩 BCD 码。功能:使用 DAA 指令时,通常先执行 ADD/ADC 指令,将两个压缩 BCD 码相加,结果存放在 AL 中,然后使用该指令将 AL 调整为压缩 BCD 码格式。DAA 的调整算法:IF
19、(AL 低 4 位9 或 AF=1)THENAL=AL+6;AF=1;ENDIFIF( AL 高 4 位9 或 CF=1)THENAL=AL+60H;CF=1;ENDIF说明:CF 反映压缩 BCD 码相加的进位。DAS;作用:调整 AL 中的差为压缩 BCD 码。功能:使用 DAS 指令时,通常先执行 SUB/SBB 指令,将两个压缩 BCD 码相减,结果存放在 AL 中,然后使用该指令将 AL 调整为压缩 BCD 码格式。DAS 的调整算法:IF(AL 低 4 位9 或 AF=1)THENAL=AL-6;AF=1;ENDIFIF( AL 高 4 位9 或 CF=1)THENAL=AL-60
20、H;CF=1;ENDIF说明:CF 反映压缩 BCD 码相减的借位。特别注意,如果使用 DAA 或 DAS 指令,则参加加法或减法运算的操作数应该是压缩 BCD码,如果将任意两个二进制数相加或相减,然后调整,则得不到正确的结果。关键是调整的规则,其中 AF 标志位就是专门为 BCD 码调整设计的,当低四位有向高四位进位或借位时,值为 1。而 CF 就是最高位有进位或者借位时,为 1.非压缩 BCD 码调整指令,包括 AAA,AAS,AAM,AAD。写法:AAA ;作用:调整 AL 中的和为非压缩 BCD 码;调整后,AL 高 4 位等于 0,AH=AH+产生的 CF功能:使用 AAA 指令时,
21、通常先执行 ADD/ADC 指令,以 AL 为目的操作数,将两个非压缩BCD 码(与高位无关)相加,然后使用 AAA 将 AL 调整为非压缩 BCD 码格式,且高 4 位等于 0,同时,将调整产生的进位加到 AH 中。AAA 调整算法:IF(AL 低 4 位9 或者 AF=1)THENAL=AL+6;AH=AH+1;AF=1;CF=1;ELSEAF=0;CF=0;ENDIFAL=AL AND OFH;AL 高 4 位清 0写法:AAS ;作用:调整 AL 中的差为非压缩 BCD 码;调整后,AL 高 4 位等于 0,AH=AH-产生的 CF功能:使用 AAS 指令时,通常先执行 SUB/SBB
22、 指令,以 AL 为目的操作数,将两个非压缩BCD 码(与高位无关)相减,然后使用 AAS 将 AL 调整为非压缩 BCD 码格式,且高 4 位等于 0,同时,将调整产生的借位从 AH 中减去。AAA 调整算法:IF(AL 低 4 位9 或者 AF=1)THENAL=AL-6;AH=AH-1;AF=1;CF=1;ELSEAF=0;CF=0;ENDIFAL=AL AND OFH;AL 高 4 位清 0写法:AAM;作用:AH=AX DIV 10, AL=AX MOD 10;功能:使用 AAM 时,通常先执行 MUL/IMUL 指令,将两个一字节非压缩 BCD 码(高四位必须为 0)相乘,结果存入
23、 AX.然后使用 AAM 指令将 AX(AH=0)调整为两字节压缩 BUC 码格式。写法:AAD;作用:AL=AH*10+AL,AH=0;功能:使用 AAD 时,通常先执行该指令,将 AX 中的两字节非压缩 BCD 码(AH 与 AL 的高4 位必须为 0)调整为相应的二进制表示,然后使用 DIV/IDIV 指令,除以一个一字节的非压缩 BCD 码(高四位必须为 0),可得到非压缩 BCD 码的除法结果。特别注意,参加非压缩 BCD 码乘法或除法的操作数高 4 位必须为 0。-算术指令结束-位操作指令开始-25、ANDORXORNOTTEST写法:AND reg/mem,reg/mem/imm
24、;OR reg/mem,reg/mem/imm;XOR reg/mem,reg/mem/imm;NOT reg/mem;TEST reg/mem,reg/mem/imm;作用:ANDTESTORXOR,两个操作数必须类型匹配,而且不能同时是内存操作数。XOR 通常用来将寄存器清 0,如 XOR AX,AX;TEST 与 AND 的关系类似于 CMP 与 SUB。TEST 的典型用法是检查某位是否为 1,如:TEST DX,109H;若 DX 的第 0,3,8 位至少有一位为 1,则 ZF=0,否则 ZF=1;26、移位指令SHL(逻辑左移)写法:SHL REGmem,1CL ;作用:将 des
25、t 的各个二进制位向左移动 1(CL)位,并将 DEST 的最高位移出到 CF,最低位移入 0。SAL(算术左移)写法:SAL REGmem,1CL ;作用:将 dest 的各个二进制位向左移动 1(CL)位,并将 DEST 的最高位移出到 CF,最低位移入 0(同 SHL)。SHR(逻辑右移)写法:SHR REGmem,1CL ;作用:将 dest 的各个二进制位向左移动 1(CL)位,并将 DEST 的最低位移出到 CF,最高位移入 0。SAR(算术右移)写法:SAR REGmem,1CL ;作用:将 dest 的各个二进制位向左移动 1(CL)位,并将 DEST 的最低位移出到 CF,最
26、高位不变。SHLD(双精度左移)写法:SHLD REG16/REG32/MEM16/MEM32, REG16/REG32, IMM8/CL;(类型须匹配)作用:将 OPRD1 的各二进制左移,并将 oprd1 的最高位移到CF,oprd2 的最高位移到 oprd1 的最低位,但是,oprd2 的值不变。SHRD(双精度右移)写法与作用与双精度左移类似。注意移动方向为右移。以上位移指令对标志位的影响:若移位后符号位发生了变化,则 OF=1,否则 OF=0;CF 为最后移入位;按一般规则影响 ZF 与 SF。然而,若移位次数为 0,则不影响标志位;若移位次数大于 1,则 OF 无定义。27、循环移
27、位指令ROL(循环左移)写法:ROL REGMEM, 1CL;或 ROL REG/MEM,IMM8;(类型可不匹配)作用:将 DEST 的各二进制位向左移动,并将最高位移出到 CF,并同时移入最低位。ROR(循环右移)写法:ROR REGMEM, 1CL;或 ROR REG/MEM,IMM8;(类型可不匹配)作用:将 DEST 的各二进制位向右移动,并将最低位移出到 CF,并同时移入最高位。RCL(带进位循环左移)写法:RCL REGMEM, 1CL;或 RCL REG/MEM,IMM8;(类型可不匹配)作用:将 DEST 的各二进制位向左移动,并将最高位移出到 CF,原 CF移入最低位。RC
28、R(带进位循环右移)写法:RCR REGMEM, 1CL;或 RCR REG/MEM,IMM8;(类型可不匹配)作用:将 DEST 的各二进制位向右移动,并将最低位移出到 CF,原 CF移入最高位。28、位测试指令BT(位测试)写法:BT REG16/MEM16,REG16/IMM8;或 BT REG32/MEM32,REG32/IMM8;作用:CF=DEST 的第 index 位,dest 不变。BTS(位测试并置位)写法:BTS REG16/MEM16,REG16/IMM8;或 BTS REG32/MEM32,REG32/IMM8;作用:CF=DEST 的第 index 位,dest 的第
29、 index 位=1;BTR(位测试并复位)写法:BTR REG16/MEM16,REG16/IMM8;或 BTR REG32/MEM32,REG32/IMM8;作用:CF=DEST 的第 index 位,dest 的第 index 位=0;BTC(位测试并复位)写法:BTC REG16/MEM16,REG16/IMM8;或 BTC REG32/MEM32,REG32/IMM8;作用:CF=DEST 的第 index 位,dest 的第 index 位取反;说明:若 dest 为寄存器,则以 index 除以 16(dest 为 reg16)或32(dest 为 reg32)的余数作为测试位。
30、当然,index 最好不要超出操作数的位数。若 dest 为内存操作数,则无论其类型为字或双字,测试位为相对于起始地址的位移,例如,设 BX=50,X 为字类型的变量,则执行指令BT X,BX;后,CF=X+6 单元的第 2 位,因为 50%8=6 余 2.BTS、BTC、BTR 指令可用于并发程序设计。29、位扫描指令BSF(前向位扫描)写法:BSF reg16/reg32, reg16/reg32/mem16/mem32;(类型须匹配)作用:dest=src 中值为 1 的最低位编号(从低位向高位搜索)BSR(后向位扫描)写法:BSR reg16/reg32, reg16/reg32/me
31、m16/mem32;(类型须匹配)作用:dest=src 中值为 1 的最高位编号(从高位向低位搜索)说明:BSF 和 BSR 搜索 SRC 操作数中首次出现 1 的位置,BSF 从低位向高位搜索,BSR 反之。若找到一个 1,则置 ZF=0,并存储位编号到 DEST 操作数中。若 SRC=0,即没有 1 出现,则置 ZF=1,且 dest 的值不确定。比如,有如下二进制数 0111 1111 1010 0100执行 bsf 后,位编号为 2,执行 bsr 后,位编号为 14.30、条件置位指令通用写法:SETcc reg8/mem8作用:若条件 cc 成立,则 dest=1,否则,dest=
32、0;SETcc 有很多种命令形式,这里的 cc 只是一个描述符,具体的参见下面的三个表,其中,E(Equal)表示相等,G(Greater)表示带符号大于,L(Less)表示带符号小于,A(Above)表示无符号大于,B(Below)表示无符号小于。表一:测试单个标志位的 SETcc 指令:SETcc 指令 描述 置 1 条件SETC,SETB,SETNAE 有进位时置 1 CF=1SETNC,SETNB,SETAE 无进位时置 1 CF=0SETZ,SETE 为 0(相等)时置 1 ZF=1SETNA,SETNE 非 0(不等)时置 1 ZF=0SETS 为负时置 1 SF=1SETNS 为
33、正时置 1 SF=0SET0 溢出时置 1 OF=1SETNO 不溢出时置 1 OF=0SETP,SETPE 1的个数为偶数时置 1 PF=1SETNP,SETPO 1的个数为奇数时置 1 PF=0表二:用于带符号数比较的 SETcc 指令,这些指令常用在 CMP 指令之后,以判断带符号数的大小:SETcc 指令 描述 置 1 条件SETG,SETNLE 大于(不小于等于)时置 1 SF=OF 且 ZF=0SETGE,SETNL 大于等于(不小于)时置 1 SF=OFSETL,SETNGE 小于(不大于等于)时置 1 SFOFSETLE,SETNG 小于等于(不大于)时置 1 SFOF 或 Z
34、F=1表三:用于无符号数比较的 SETcc 指令,常用在 CMP 指令之后,用来判断无符号数的大小:SETcc 指令 描述 置 1 条件SETA,SETNBE 大于(不小于等于)时置 1 CF=0 且 ZF=0SETAE,SETNB,SETNC 大于等于(不小于)时置 1 CF=0SETB,SETNAE,SETC 小于(不大于等于)时置 1 CF=1SETBE,SETNA 小于等于(不大于)时置 1 CF=1 或 ZF=1-位操作指令结束-控制转移指令开始-31、JMP(无条件转移指令)执行代码的跳转,分为两种,一:段内转移,即要跳过去的代码地址和当前地址在同一段,这时只要修改 IP(专用寄存
35、器-指令指针)即可;二:段间转移:即要跳过去的代码地址和当前代码地址不在同一段内,需要同时修改 CS 和 IP 的值。写法:1、JMP label;若 label 与该指令位于同一代码段内,IP=label 的偏移地址,否则CS:IP=label 的分段地址,简单的说,就是跳到 label 的地址去。2、JMP reg16/mem16;段内转移,偏移地址=reg16/mem163、JMP mem32;段间间接转移,段地址 CS=mem32 高字,偏移地址 IP=mem32 低字。说明:当操作数是内存操作数时,若内存操作数是双字类型,则产生段间转移,若内存操作数是字类型,则产生段内间接转移。当不
36、能确定类型时,编译器将报错。32、Jcc(条件转移指令)写法:Jcc label;作用:若条件成立,则 IP=label 的偏移地址,否则,CPU 将忽略该条件转移,继续执行下一条指令。条件转移有以下几种形式:表一:测试单个标志位的 Jcc 指令:Jcc 指令 描述 转移条件JC,JB,JNAE 有进位时转移 CF=1JNC,JNB,JAE 无进位时转移 CF=0JZ,JE 为零(相等)时转移 ZF=1JNZ,JNE 非零(不等)时转移 ZF=0JS 为负时转移 SF=1JNS 为正时转移 SF=0JO 溢出时转移 OF=1JON 不溢出时转移 OF=0JP,JPE 1的个数为偶数时转移 PF
37、=1JNP,JPO 1的个数为奇数时转移 PF=0表二:用于带符号数比较的 Jcc 指令(常用在 CMP 指令之后,以判断带符号数的大小)Jcc 指令 描述 转移条件JG,JNLE 大于(不小于等于)时转移 SF=OF 且 ZF=0JGE,JNL 大于等于(不小于)时转移 SF=OFJL,LNGE 小于(不大于等于)时转移 SFOF 或 ZF=1表三:用于无符号数比较的 Jcc 指令(常用在 CNO 指令之后,以判断无符号数的大小)Jcc 指令 描述 转移条件JA,JNBE 大于(不小于等于)时转移 CF=0 且 ZF=0JAE,JNB,JNC 大于等于(不小于)时转移 CF=0JB,LNAE
38、,JC 小于(不大于等于)时转移 CF=1JBE,LNA 小于等于(不大于)时转移 ZF=1 或 CF=133、JCXZ/JECXZ(Jump if CX/ECX is zero)写法:JCXZ label;(若 CX=0,则转移到 label)JECXZ label;(若 ECX=0,则转移到 label)说明:label 相对位移量必须在-126127 之间34、循环指令LOOP label;作用:CX=CX-1;若 CX0 且 ZF=1,则转移到 label;LOOPNZ/LOOPNE label;作用:CX=CX-1;若 CX0 时,重复执行后面的串指令,每执行一次,CX 自动-1,该
39、指令只能用在MOVSLODSSTOS 之前REPZ/REPE(为零/等于时重复)功能:当 CX0 且 ZF=0 时,重复执行后面的指令,每执行一次,CX 自动-1,该指令只能用在 CMPSACAS 之前。说明:REPNE SCAS(B/W/D)适用于在多字节、字、双字数据结构中搜索特定值。-串操作指令结束-CPU 控制指令开始-44、NOP(无操作)写法:NOP;作用:该指令不做任何事情,只占用 1 个字节,耗费一个指令执行周期。45、HIT(暂停)写法:HIT;作用:HIT 使 CPU 进入暂停状态,这时 CPU 不执行任何操作,直到系统复位或发生外部中断为止,中断使 CPU 继续执行后面的
40、指令(貌似和屏保或待机的功能类似)46、LOCK(封锁前缀)功能:LOCK 指令用于多处理器系统,作为某些指令的前缀,可以使 CPU 通过锁住总线等方式,抱着指令作为原子性操作,即:指令执行过程不会被打断操作。该指令用于以下指令的前缀时,以保证原子性的对内存的“读-修改-写”操作:1) 加法:ADDADCINCXADD2) 减法:SUBSBBDECNEG3) 交换:XCHGCMPXCHGCMPXCHG8B4) 逻辑:ANDNOTORXOR5) 位测试:BTSBTCBTR说明:其他类型指令不能加 LOCK 前缀,另外,XCHG 总是原子性操作,无论前面有没有加LOCK 前缀。LOCK 前缀典型用于 BTS 指令,以实现多处理器环境中程序的并发执行,如:LOCK BTS EBX,AXLOCK ADD SI,AL-CPU 控制指令结束