还剩27页未读,继续阅读
本资源只提供10页预览,全部文档请下载后查看!喜欢就下载吧,查找使用更方便
文本内容:
汇编指令全集ZZ以下是80X86汇编过程中经常用到的一些汇编指令从功能分类上来说,一共可分为数据传送指令MOV、XCHG、LEA、LDS、LES、PUSH、POP、PUSHF、POPF、CBW、CWD、CWDEo算术指令ADD、ADC、INC、SUB、SBB、DEC、CMP、MUL、DIV、DAA、DAS、AAA、AASo逻辑指令AND、OR、XOR、NOT、TEST、SHL、SAL、SHR、SARRCL、RCR、ROL、RORo控制转移指令:JMP、Jcc、JCXZ、LOOP、LOOPZ、LOOPNZ、LOOPNE、CALL、RET、INT串操作指令MOVS、LODSSTOS、CMPS、SCASo标志处理指令CLC、STC、CLD、STDo
七、32位CPU新增指令数据传送指令MOV(传送)指令写法MOVtargetsource注意这里并不将结果存入dest中,而仅仅是执行相减的运算,达到依据运算结果去影响EFLAG标志位的效果
19、NEG(求补)写法NEGreg/mem作用:求补就是求相反数即dest=O-dest;
20、CMPXCHG(比较交换)写法CMPXCHGreg/memreg;作用AL/AX/EAX-oprdl如果等于0则oprdl=oprd2否则,AL/AX/EAX=oprdl;即比较AL/AX/EAX与第一个操作数,如果相等,则置ZF=1并复制第二个操作数给第一个操作数;否则,置ZF=0并复制第一个操作数给AL/AX/EAXo说明CMPXCHG主要为实现原子操作提供支持CMPXCHG8B(8字节比较交换指令)写法CMPXCIIG8BMEM64;功能将EDX:EAX中的64位数与内存的64位数进行比较,如果相等则置ZF=1并存储ECX:EBX到mem64指定的内存地址;否则,置ZF=0并设置EDX:EAX为mem64的8字节内容
21、MUL(无符号乘法)写法MULreg/mem;作用当操作数为8位时,AX=AL*src;当操作数为16位时,DX:AX=AX*src;当操作数为32位时,EDX:EAX=EAX*src;
22、IMUL(带符号位乘法)写法IMULreg/mem;(作用同上)IMULregl6regl6/meml6imml6;IMULreg32reg32/mem32imm32;IMULregl6imml6/regl6/imml6;IMULreg32reg32/mem32/imm32;注意没有两个操作数均为8位的多操作数乘法对于同一个二进制数,采用MUL和IMUL执行的结果可能不同,设AL二OFFBL=1分别执行下面的指令,会得到不同的结果Muibl;AX=OFFH
(255);Imulbl;AX=OFFFFH(-1)(高一半为低一半的扩展)
23、DIV(无符号除法)/IDIV(带符号数除法)写法DIVreg/mem;/IDICreg/mem作用如果操作数是8位,AX%SRC结果商在AL、余数在AH中;如果操作数是16位,DX:AX%SRC结果商在AX余数在DX中;如果操作数是32位,EDX:EAX%SRC结果商在EAX余数在EDX中;注意不能直接实现8位数除8位数、16位数除16位数、32除32若需要这样,则必须先把除数符号扩展或零扩展到
16、
32、64位,然后用除法指令对于IDIV余数和被除数符号相同,如-5IDIV2二商-2余数:-1;在下列情况下,会使CPU产生中断一除数为0;二由于商太大导致EAX\AX或AL不能容纳,从而产生了溢出BCD码调整指令(十进制调整指令)待补充
24、关于BCD码BCD码就是一种十进制数的二进制编码表示,分为压缩BCD码和非压缩BCD码,压缩BCD码用4个二进制位表示一个十进制位,即用0000B1001B表示十进制0~9如0110010000101001B表示6429用8位二进制来表示一个十进制叫非压缩BCD码,其中,低四位与压缩BCD码相同,高四位无意义压缩BCD码调整指令包括DAA(加法的压缩BCD码调整)和DAS(减法的压缩BCD码调整)写法DAA;作用调整AL中的和为压缩BCD码功能使用DAA指令时,通常先执行ADD/ADC指令,将两个压缩BCD码相加,结果存放在AL中,然后使用该指令将AL调整为压缩BCD码格式DAA的调整算法IF(AL低4位>9或AF=1)THENAL=AL+6;AF=1;ENDIFIF(AL高4位>9或CF=1)THI-NAL=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=DTHENAL=AL-60H;CF=1;ENDIF说明CF反映压缩BCD码相减的借位特别注意,如果使用DAA或DAS指令,则参加加法或减法运算的操作数应该是压缩BCD码如果将任意两个二进制数相加或相减,然后调整,则得不到正确的结果关键是调整的规则,其中AF标志位就是专门为BCD码调整设计的,当低四位有向高四位进位或借位时,值为1而CF就是最高位有进位或者借位时,为
1.非压缩BCD码调整指令,包括AAAAASAAMAADo写法AAA;作用调整AL中的和为非压缩BCD码;调整后,AL高4位等于0AH=AH+产生的CF功能使用AAA指令时,通常先执行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=ALANDOFH;;AL高4位清0写法AAS;作用调整AL中的差为非压缩BCD码调整后,AL高4位等于0AH=AH-产生的CF功能使用AAS指令时,通常先执行SUB/SBB指令,以AL为目的操作数,将两个非压缩BCD码(与高位无关)相减,然后使用AAS将AL调整为非压缩BCD码格式,且高4位等于0同时,将调整产生的借位从All中减去AAA调整算法IF(AL低4位>9或者AF=1)THENAL=AL-6;AH=AH-1;AF=1;CF=1;ELSEAF=0;CF=0;ENDIFAL=ALANDOFH;;AL高4位清0写法AAM;作用AH=AXDIV10AL二AXMOD10;功能使用AAM时,通常先执行MUL/IUUL指令,将两个一字节非压缩BCD码(高四位必须为0)相乘,结果存入AX.然后使用AAU指令将AX(AH=O)调整为两字节压缩BUC码格式写法AAD;作用AL=AH*10+ALAH=0;功能使用AAD时,通常先执行该指令,将AX中的两字节非压缩BCD码(AH与AL的高4位必须为0)调整为相应的二进制表示,然后使用DIV/IDIV指令,除以一个一字节的非压缩BCD码(高四位必须为0)可得到非压缩BCD码的除法结果特别注意,参加非压缩BCD码乘法或除法的操作数高4位必须为0o算术指令结束位操作指令开始
25、AND\OR\XOR\NOT\TEST写法ANDreg/menireg/mem/imm;ORreg/memreg/mem/imm;XORreg/memreg/mem/imm;NOTreg/mem;TESTreg/memreg/mem/imm;作用AND\TEST\OR\XOR两个操作数必须类型匹配,而且不能同时是内存操作数XOR通常用来将寄存器清0如XORAXAX;TEST与AND的关系类似于CMP与SUBTEST的典型用法是检查某位是否为1如TESTDX109H;若DX的第038位至少有一位为1则ZF=O否则ZF=1;
26、移位指令SHL(逻辑左移)写法SHLREG\mem1\CL;作用将dest的各个二进制位向左移动1(CL)位高位移出到CF最低位移入0SAL(算术左移)写法SALREG\mem1\CL;作用将dest的各个二进制位向左移动1(CL)位,并将DEST的最高位移出到CF最低位移入0(同SHL)oSIIR(逻辑右移)写法SHRREG\mem1\CL;作用将dest的各个二进制位向左移动1(CL)位并将DEST的最低位移出到CF最高位移入0SAR(算术右移)写法SARREG\mem1\CL;作用将dost的各个二进制位向左移动1(CL)位,并将DEST的最低位移出到CF最高位不变SHLD(双精度左移)写法SHLDREG16/REG32/MEM16/MEM32REG16/REG32IMM8/CL;(类型须匹配)作用将0PRD1的各二进制左移并将oprdl的最高位移到CFoprd2的最高位移到oprdl的最低位,但是,oprd2的值不变SHRD(双精度右移)写法与作用与双精度左移类似注意移动方向为右移以上位移指令对标志位的影响若移位后符号位发生了变化,则OF=1否则0F=0;CF为最后移入位;按一般规则影响ZF与SF然而,若移位次数为0则不影响标志位;若移位次数大于1则0F无定义
27、循环移位指令R0L(循环左移)写法ROLREG\MEM1\CL;或ROLREG/MEMIMM8;(类型可不匹配)作用将DEST的各二进制位向左移动,并将最高位移出到CF并同时移入最低位R0R(循环右移)写法RORREG\MEM1\CL;或RORREG/MEMIMM8;(类型可不匹配)作用将DEST的各二进制位向右移动,并将最低位移出到CF并同时移入最高位RCL(带进位循环左移)写法RCLREG\MEM1\CL;或RCLREG/MEMIMM8;(类型可不匹配)作用将DEST的各二进制位向左移动,并将最高位移出到CF原CF移入最低位RCR(带进位循环右移)写法RCRREG\MEM1\CL;或RCRREG/MEMIMM8;(类型可不匹配)作用将DEST的各二进制位向右移动,并将最低位移出到CF原CF移入最高位
28、位测试指令BT(位测试)写法BTREG16/MEM16REG16/IMM8;BTREG32/MEM32REG32/1MM8;作用:CF=DEST的第index位,dest不变BTS(位测试并置位)写法BTSREG16/MEM16REG16/IMM8;或BTSREG32/MEM32REG32/1MM8;作用作二DEST的第index位,dest的第index位二1;功能描述将源操作数source的值复制到target中去,source值不变注意事项1)target不能是CS(代码段寄存器),我的理解是代码段不可写,只可读,所以相应这地方也不能对CS执行复制操作2)target和source不能同时为内存数、段寄存器(CS\DS\ES\SS\FS\GS)3)不能将立即数传送给段寄存器4)target和source必须类型匹配,比如,要么都是字节,要么都是字或者都是双字等4)由于立即数没有明确的类型,所以将立即数传送到target时,系统会自动将立即数零扩展到与target数的位数相同,再进行传送有时,需要用BYTEPTR、WORDPTR、DWORDPTR明确指出立即数的位数写法示例MOVdl01H;MOVeax[bp];eax=ss:[bp]双字传送XCHG(交换)指令写法:xCHGobjectlobject2功能描述交换objectl与object的值注意事项1)不能直接交换两个内存数的值2)类型必须匹配3)两个操作数任何一个都不能是段寄存器【看来段寄存器的写入的限制非常的严格,MOV指令也不能对段寄存器进行写入】,4)必须是通用寄存器(ax、bx、ex、dx、si^di)或内存数写法示例XCHGax[bx][si];XCHGaxbx;BTR(位测试并复位)写法:BTRREG16/MEM16REG16/IMM8;或BTRREG32/MEM32REG32/IMM8;作用CF=DEST的第index位,dest的第index位=0;BTC(位测试并复位)写法BTCREG16/MEM16REG16/IMM8;或BTCREG32/MEM32REG32/1MM8;作用CF=DEST的第index位,dest的第index位取反;说明若dest为寄存器,则以index除以16(dest为regl6)或32(dest为reg32)的余数作为测试位当然,index最好不要超出操作数的位数若dest为内存操作数,则无论其类型为字或双字,测试位为相对于起始地址的位移,例如,设BX=50X为字类型的变量,则执行指令BTXBX;后,CF=X+6单元的第2位,因为50烧工6余
2.BTS、BTC、BTR指令可用于并发程序设计
29、位扫描指令BSF(前向位扫描)写法BSFregl6/rcg32reg16/reg32/mcm16/mom32;(类型须匹配)作用dest=src中值为1的最低位编号(从低位向高位搜索)BSR(后向位扫描)写法BSRregl6/reg32reg16/reg32/mem16/mem32;(类型须匹配)作用dest二src中值为1的最高位编号(从高位向低位搜索)说明BSF和BSR搜索SRC操作数中首次出现1的位置,BSF从低位向高位搜索,BSR反之若找到一个1,则置ZF=O并存储位编号到DEST操作数中若SRC=O即没有1出现,则置ZF=L且dest的值不确定比如,有如下二进制数()111111110100100执行bsf后,位编号为2执行bsr后,位编号为
14.
30、条件置位指令通用写法SETccreg8/mem8作用若条件cc成立,则dest=l否则,dest=0;SETcc有很多种命令形式,这里的cc只是一个描述符,具体的参见下面的三个表,其中,E(Equal)表示相等G(Greater)表示带符号大于,L(Less)表示带符号小于,A(Above)表示无符号大于,B(Below)表示无符号小于表一测试单个标志位的SETcc指令表二用于带符号数比较的SETcc指令,这些指令常用在CMP指令之后,以判断带符号数的大小表三用于无符号数比较的SETcc指令,常用在CUP指令之后,用来判断无符号数的大小:位操作指令结束一控制转移指令开始
31、JUP(无条件转移指令)执行代码的跳转,分为两种,一段内转移,即要跳过去的代码地址和当前地址在同一段这时只要修改IP(专用寄存器一指令指针)即可;二段间转移即要跳过去的代码地址和当前代码地址不在同一段内,需要同时修改CS和IP的值写法
1、JMPlabel;若label与该指令位于同一代码段内,IP=label的偏移地址,否则CS:IP=label的分段地址简单的说,就是跳到label的地址去
2、JMPregl6/mem16;段内转移,偏移地址;reg16/[mem16]
3、JMPmem32;段间间接转移段地址CS二mem32高字,偏移地址IP二mem32低字说明当操作数是内存操作数时,若内存操作数是双字类型,则产生段间转移,若内存操作数是字类型,则产生段内间接转移当不能确定类型时,编译器将报错
32、Jcc(条件转移指令)写法Jcclabel;作用若条件成立,则IP=label的偏移地址,否则,CPU将忽略该条件转移,继续执行下一条指令条件转移有以下几种形式表一测试单个标志位的JCC指令表二用于带符号数比较的Jcc指令(常用在CMP指令之后,以判断带符号数的大小)表三用于无符号数比较的Jcc指令(常用在CNO指令之后,以判断无符号数的大小)
33、JCXZ/JECXZJumpifCX/ECXiszero写法JCXZlabel;(若CX=O则转移到label)JECXZlabel;(若ECX=O则转移到label)说明label相对位移量必须在-126〜127之间
34、循环指令LOOPlabel作用:CX=CXT;若CXOO则转移到label;LOOPZ/LOOPElabel;作用CX=CX-1;若CXOO且ZF=1则转移到label;LOOPNZ/LOOPNElabel;作用:CX=CX-1;若CX〈>0且ZF=O则转移到label;说明label相对位移量必须在-128〜127之间
35、过程调用和返回指令CALL(过程调用)写法CALLlabel;作用若label与该指令在同一代码段,则为段内直接调用,IP进栈,lP=label的偏移地址,如果是不在同一代码段,则为段间间接调用,CS:IP进栈,CS:IP=labol的分段地址写法CALLregl6/meml6;作用段内间接调用,IP进栈,IP=regl6/【meml6】写法CALLmem32;作用段间间接调用,CS:IP进栈,CS等于mcm32高字,ip等于mcm32低字该指令与JMP指令的区别就是保存了CS:IP的值,这样在调用指令结束后,可以返I中可来而已RET(过程返回)写法RET;近返回或远返回RETN;近返回;RETF;远返回RETimml6;近返回或远返回,并调整堆栈,SP=SP+imml6;RETNimml6;近返回并调整堆栈,SP=SP+imml6;RETFinunl6;远返回,并调整堆栈,SP=SP+imml6;作用RET/RETN/RETF返回地址出栈,从而使调用返回,其中,远返回是POP一个双字到CS:IP而近返回是POP一个字到IPRET/RETN/RETFimml6在返回后,CPU立即将imml6加到堆栈指针SP这种机制用来在返回前将参数从栈中移除说明CALL与RET必须配合使用,并且确保返阿I时栈顶正好是返回地址,不然就会出错
36、INT(中断指令)写法INTn;(n为中断号,取值为
0、255)通常,程序内部的跳转,用JMP或CALL并且JMP和CALL得参数是要跳转的过程的入口指令地址,而INT则是调用系统提供的中断服务程序,并且参数是中断号,然后由CPU根据中断号去计算中断服务程序的入口地址,MSDOS使用中断号21H作为系统调用,一般INT中断的步骤如下
(1)由AH给出中断号
(2)根据相应功能的要求,设置入口参数
(3)INT21H
(4)分析和使用出口参数比如如下代码实现程序的退出并返回DOS Movah4ch;给出中断号Int21h;开始中断说明除了直接以AL或AX返回出口参数外,INT21H还是用AL或AX作为返回码,对于功能号0~2eh由AL返回0(表示成功)或1(表示失败);其余功能号则由CF返回0或者1并由AX返回错误码-控制转移指令结束标志处理指令开始标志处理指令结束串操作指令开始到这为止,所涉及的指令都是处理一个操作数,如果要处理连续内存单元的一批数据,通常需借助于循环而串操作指令就可以用来处理内存中的数据串,并在助记符后面加上B、W、D分别表示操作类型为字节、字或双字
38、MOVS串传送写法MOVSB/MOVSW/MOVSD功能ES:[DI]=DS:[SI]IfDF=OThenSI=SI+size;DI=DI+size;ElseSI=SI-size;DI=DI-size;Endif其中,size等于1B、2W、4【.作用将DS:SI所指源串的一个字节/字/双字复制到ES:DI所指的内存单元,然后,若DF=O则SI和DI增加
1、
2、4否则减少
1、
2、
4.现在有点明白为什么SI为源变址寄存器,而11为目标变址寄存器了,而DS为数据段寄存器,ES为附加段寄存器了
39、LODS串载入写法LODSB\LODSW\LODSD功能AL/AX/EAX=DS:[SI];IFDF=OTHENSI=SI+size;ELSESI=SI-size;Endif作用将DS:SI所指源串的值复制到AL/AX/EAX中然后,根据DF使SI增加或减小
1、
2、
440、STOS串存储写法STOSB\STOSW\STOSD功能ES:[DI]=AL/AX/EAX;IFDF=0THENDI=DI+size;ELSEDI=DI-size;ENDIF作用将AL/AX/EAX中的值复制到ES:[DI]所指的内存单元中去,并根据DF标志位的值调整DI
41、CMPS串比较写法:CMPSB/CMPSW/CMPSD功能DS:[SI]-ES:[DI];IFDF=0THENSI=SI+size;DI=DI+size;ELSESI=SI-size;DI=DI-size;ENDIF作用将DS:SI所指内存值与ES:DI所指内存值进行比较,并根据比较结果设置标志位,然后,对SI和DI做相应的调整
42、SCAS(串扫描)写法SCASB/SCASW/SCASD功能AL/AX/EAX-ES:[DI];IF(CF=O)THENDI=DI+size;ELSEI)川-size;ENDIF作用将AL/AX/EAX与ES:DI所指内存值进行比较,根据比较结果设置标志位,然后根据DF调整相应的DI的值说明以上串操作的共性DS:SI指向源串,ES:DI指向目的串SI和DI自动增加或减少
1、
2、4关键看DF及操作类型是B\W\D
43、重复前缀重复前缀用来和以上几个串操作指令混合使用REP(重复)功能当CX0时,重及执行后面的串指令,每执行一次,CX自动T该指令只能用在MOVS\LODS\STOS之前REPZ/REPE(为零/等于时重复)功能当CX0且ZF=1时,重复执行后面的指令,每执行一次,CX自动T该指令只能用在CMPS\ACAS之前REPNZ/REPNE(非零/不等于时重复)功能CXOO且ZF=O时,重复执行后面的指令,每执行一次,CX自动-1该指令只能用在CMPS\ACAS之前说明REPNESCAS(B/W/D)适用于在多字节、字、双字数据结构中搜索特定值串操作指令结束CPU控制指令开始
44、NOP(无操作)写法NOP;作用该指令不做任何事情,只占用1个字节,耗费一个指令执行周期
45、HIT(暂停)写法HIT;作用HIT使CPU进入暂停状态,这时CPU不执行任何操作,直到系统复位或发生外部中断为止,中断使CPU继续执行后面的指令(貌似和屏保或待机的功能类似)
46、LOCK(封锁前缀)功能LOCK指令用于多处理器系统,作为某些指令的前缀,可以使CPL•通过锁住总线等方式,抱着指令作为原子性操作,即指令执行过程不会被打断操作该指令用于以下指令的前缀时,以保证原子性的对内存的“读-修改-写”操作1)加法ADD\ADC\INC\XADD2)减法SUB\SBB\DEC\NEG3)交换XCHG\CMPXCHG\CMPXCHG8B4)逻辑:AND\NOT\OR\XOR5)位测试BTS\BTC\BTR说明其他类型指令不能加LOCK前缀,另外,XCHG总是原子性操作,无论前面有没有加LOCK前缀LOCK前缀典型用于BTS指令,以实现多处理器环境中程序的并发执行,如LOCKBTS[EBX]AXLOCKADD[SI]ALLEA(装入有效地址)指令写法LEZregl6mem功能描述将有效地址MEM的值装入到16位的通用寄存器中写法示例假定bx=5678HEAX=1EDX=2Leasi2[bx];si=567AHLeadi2[eax][edx];di=5注意,这里装入的是有效地址,并不是实际的内存中的数值,如果要想取内存中该地址对应的数值,还需要加上段地址才行,而段地址有可能保存在DS中,也有可能保存在SS或者CS中哦)不知道我的理解可正确LDS\LES\LGS\LSS(注意,与LEA不同的是,这里是装入的值而不是有效地址)这几个指令,名称不同,作用差不多写法LDSregl6mem32功能描述regl6等于mem32的低字,而DS对应于mem32的高字(当为LES时,这里就是ES对应于mem32的高字)用来给一个段寄存器和一个16位通用寄存器同时复制注意事项第一个操作数必须是16位通用寄存器在接着往下说之前,先熟悉下堆栈的概念堆栈,位于内存的堆栈段中,是内存的一部分,具有“先进后出”的特点,堆栈只有一个入口,即当前栈顶,当堆栈为空时,栈顶和栈底指向同一内存地址在WINDOWS中,可以把堆栈理解成一个倒着的啤酒瓶,上面的地址大,下面的地址小,当从瓶口往啤酒瓶塞啤酒时(进栈),栈顶就会往瓶口下移动,也就是往低地址方向移动,同理,出栈时,正好相反,把啤酒给倒出来,栈顶向高地址方向移动这就是所谓的堆栈哼哼,很Easy吧在汇编语言中,堆栈操作的最小单位是字,也就是说,只能以字或双字为单位,同时,SS SP指向栈顶(SS为堆栈段寄存器,SP为堆栈指针,二者一相加,就构成了堆栈栈顶的内存地址)PUSH(进栈)写法PUSHregl6
(32)/seg/meml6
(32)/imm功能描述将通用寄存器/段寄存器/内存数/立即数的值压入栈中,即SP=SP-2SS:[SP]=16位数值(当将32位数值压入栈中时,SP=SP-4SS:[SP]=32为数值)POP(出栈)写法POPregl632/seg/meml632【不能出栈到CS中】功能描述将堆栈口的16
(32)位数据推出到通用寄存器/段寄存器/内存中,即寄存器/段寄存器/内存二SS:[SP]SP=SP+2(当将32位数值出栈时,SP=SP+4)(注意,不能出栈给立即数哦,常量不可变嘛)PUSHA、PUSHAD、POPA、POPAD作用将所有16/32位通用寄存器进栈/出栈如:PUSHA;将人乂、CX、DX、BX、原SP、BP、ST.DI依次进栈POPA出栈顺序正好相反,但要注意的是,弹出到SP的值被丢弃SP通过增加16位来恢复(当然嘛,不然栈顶地址就被修改了,就会出息不对齐的情况,就有可能乱套了)POPADPUSHAD一样,只不过是32位的罢了PUSHF、PUSHFD、POPF、POPFD功能描述标志寄存器FLAGS(EFLAGS)进栈或出栈如PUSHF;FLAGS进栈POPF;栈顶字出栈到FLAGS总结下,POP和PUSH通常可以用来交换两个寄存器的值,也可以用来保护寄存器的值,如下交换ax与ex的值pushax;pushex;popax;popex;保护寄存器:pushax;pushex;・•・.中间有很多执行的代码…popex;popax;
9、LAHF\SAHF(标志寄存器传送指令)写法lahf;作用AH二FLAGS的低8位写法sahf;作用FLAGS的低8位二AH
10、符号扩展和零扩展指令CBW;AL符号扩展为AXCWD;AX符号扩展为32位数DX:AXCWDE;AX符号扩展为EAX;CDQ EAX符号扩展为64位数EDX:EAXM0VSX(符号扩展指令的一般形式)写法MOVSXregl6\32reg8\reg16\mem8\mem16作用用来将8位符号扩展到16位,或者16位符号扩展到32位M0VZX(零扩展指令)写法MOVZXregl6\32reg8\reg16\mem8\mem16零扩展,就是高位补0进行扩展通常用在将数据复制到一个不同的寄存器中,如AL零扩展为EBX相同寄存器的零扩展,可以使用MOV高位,0来实现
11、BSWAP(字节交换)写法bswapreg32作用将reg32的第0与第3个字节,第1与第2个字节进行交换示例设EAX=12345678h执行bswapeax;后,eax=78563412H
12、XLAT(换码)写法XLAT;作用AL=DS:[bx+AL]将DS:BX所指内存中的由AL指定位移处的一个字节赋值给ALo(貌似这是一个方便偷懒的指令哦),原来它的主要用途是查表注意可以给它提供操作数,用来指定使用哪个段地址,如XLATES table;使用ES来作为段地址,table不起作用XLATtable;使用table所在段对应的段寄存器作为段地址数据传送指令结束算术指令开始
13、ADD(加法)写法ADDreg/memreg/mem/imm作用将后面的操作数加到前面的操作数中注意两个操作数必须类型匹配,并且不能同时是内存操作数ADC(带进位加法)写法ADCreg/memreg/mem/imm;作用dest=dest+src+cf当CF=O时ADI)与ADC的作用是相同的示例实现64位数EDX:EAX与ECX:EBX的加法AddEAXEBX;ADCEDXECX;
14、INC(自加一)写法INCreg/mem;
15、XADD(交换加)写法XADDreg/memreg作用先将两个数交换,然将二者之和送给第一个数
16、SUB(减法)写法SUBreg/memreg/mem/imm;作用dest=dest-src;SBB(带借位减法)写法SBBreg/memreg/mem/imm作用dest=dest-src-cf;注意两个操作数必须类型匹配,且不能同时是内存数
17、DEC(自减1)写法DECreg/mem;作用dest=dest-l;
18、CMP(比较)写法CMPreg/memreg/mem/imm作用dest-srcSETcc指令描述置1条件SETCZSETBZSETNAE有进位时置1CF=1SETNCZSETNBZSETAE无进位时置1CF=0SETZSETE为0(相等)时置1ZF=1SETNASETNE非0(不等)时置1ZF=OSETS为负时置1SF=1SETNS为正时置1SF=OSETO溢出时置1OF=1SETNO不溢出时置1OF=0SETPSETPE1的个数为偶数时苴1PF=1SETNPSETPOT的个数为奇数时置1PF=OSETcc指令描述置1条件SETGSETNLE大于(不小于等于)时置.1SF=OFB.ZF=0SETGESETNL大于等于(不小于)时置1SF=OFSETLSETNGE小于(不大于等于)时置.1SFwOFSETLESETNG小于等于(不大于)时置.1SFwOF或ZF=1SETcc指令描述置1条件SETAZSETNBE大于(不小于等于)时置1CF=O且ZF=OSETAESETNBSETNC大于等于(不小于)时置1CF=OSETBSETNAESETC小于(不大于等于)时置1CF=1SETBESETNA小于等于(不大于)时置1CF=1或ZF=1Jcc指令描述转移条件JCJBJNAE有进位时转移CF=1JNCJNBJAE无进位时转移CF=OJZJE为零(相等)时转移ZF=1JNZJNE非零(不等)时转移ZF=0JS为负时转移SF=1JNS为正时转移SF=0JO溢出时转移OF=1JON不溢出时转移OF=0JPJPE1的个数为偶数时转移PF=1JNPJPO1的个数为奇数时转移PF=0Jcc指令描述转移条件JGJNLE大于(不小于等于)时转移SF=OF且ZF=0JGEJNL大于等于(不小于)时转移SF=OFJLLNGE小于(不大于等于)时转移SFoOFJLELNG小于等于(不大于)时转移SFvOF或ZF=1Jcc指令描述转移条件JAJNBE大于(不小于等于)时转移CF=0且ZF=0JAEJNBJNC大于等于(不小于)时转移CF=0JBLNAEJC小于(不大于等于)时转移CF=1JBELNA小于等于(不大于)时转移ZF=1或CF=1。