汇编语言指令大全
- 格式:doc
- 大小:205.50 KB
- 文档页数:22
常见汇编代码汇编语言是一种低级语言,主要用于编写计算机的指令集。
在程序开发和系统调试中,掌握常见的汇编代码是非常重要的。
本文将介绍一些常见的汇编代码及其用途。
一、数据传输指令1. MOV:将数据从一个位置复制到另一个位置。
例如,MOV AX, BX将BX寄存器中的数据复制到AX寄存器中。
2. XCHG:交换两个位置的数据。
例如,XCHG AX, BX将AX寄存器和BX寄存器中的数据进行交换。
3. PUSH:将数据推入栈中。
例如,PUSH AX将AX寄存器的数据推入栈中。
4. POP:将数据从栈中弹出。
例如,POP AX将从栈中弹出的数据存储到AX寄存器中。
二、算术指令1. ADD:将两个数相加并将结果存储在目标位置。
例如,ADD AX, BX将AX寄存器和BX寄存器中的数据相加,并将结果存储到AX寄存器中。
2. SUB:将两个数相减并将结果存储在目标位置。
例如,SUB AX, BX将AX寄存器中的数据减去BX寄存器中的数据,并将结果存储到AX寄存器中。
3. MUL:将两个数相乘并将结果存储在目标位置。
例如,MUL AX, BX将AX寄存器和BX寄存器中的数据相乘,并将结果存储到AX寄存器中。
4. DIV:将两个数相除并将结果存储在目标位置。
例如,DIV AX, BX将AX寄存器中的数据除以BX寄存器中的数据,并将商存储到AX寄存器中。
三、逻辑指令1. AND:对两个数进行逻辑与操作,并将结果存储在目标位置。
例如,AND AX, BX将AX寄存器和BX寄存器中的数据进行逻辑与操作,并将结果存储到AX寄存器中。
2. OR:对两个数进行逻辑或操作,并将结果存储在目标位置。
例如,OR AX, BX将AX寄存器和BX寄存器中的数据进行逻辑或操作,并将结果存储到AX寄存器中。
3. XOR:对两个数进行逻辑异或操作,并将结果存储在目标位置。
例如,XOR AX, BX将AX寄存器和BX寄存器中的数据进行逻辑异或操作,并将结果存储到AX寄存器中。
汇编语言跳转指令在计算机编程中,汇编语言是与机器语言最接近的一种编程语言,它使用助记符来表示指令和数据,通过编写汇编语言程序可以直接操控计算机的底层硬件。
在汇编语言中,跳转指令是非常重要的一种指令,它用于修改程序的执行流程,实现程序的控制和逻辑跳转。
本文将介绍汇编语言中常见的跳转指令及其使用方法。
一、无条件跳转指令1. JMP(跳转)指令JMP指令用于无条件地跳转到指定的目标地址。
它可以直接跳转到一个标签或者给出一个绝对地址作为跳转目标。
下面是JMP指令的语法格式:JMP 目标地址例如,要跳转到标签"LOOP"所在的位置,可以使用以下指令:JMP LOOP2. JC(进位跳转)指令JC指令用于判断运算结果是否产生了进位,并根据判断结果进行跳转。
如果进位标志位CF被设置为1,则跳转到指定的目标地址;否则,继续顺序执行下一条指令。
下面是JC指令的语法格式:JC 目标地址例如,要在进位发生时跳转到标签"OVERFLOW"所在的位置,可以使用以下指令:JC OVERFLOW二、条件跳转指令条件跳转指令用于根据特定条件是否满足来进行跳转。
常用的条件跳转指令有以下几种:1. JE/JZ(等于/零)指令JE/JZ指令用于判断两个数是否相等或某个操作数是否为零,并根据判断结果进行跳转。
如果条件满足,则跳转到指定的目标地址;否则,继续顺序执行下一条指令。
下面是JE/JZ指令的语法格式:JE/JZ 目标地址例如,要在相等时跳转到标签"EQUAL"所在的位置,可以使用以下指令:JE EQUAL2. JNE/JNZ(不等于/非零)指令JNE/JNZ指令用于判断两个数是否不相等或某个操作数是否非零,并根据判断结果进行跳转。
如果条件满足,则跳转到指定的目标地址;否则,继续顺序执行下一条指令。
下面是JNE/JNZ指令的语法格式:JNE/JNZ 目标地址例如,要在不相等时跳转到标签"UNEQUAL"所在的位置,可以使用以下指令:JNZ UNEQUAL3. JA/JNBE(大于/不低于)指令JA/JNBE指令用于比较两个数的大小关系,并根据判断结果进行跳转。
汇编nop指令一、概述汇编语言是一种低级语言,它直接操作计算机硬件,与高级语言相比,汇编语言更加灵活和高效。
在汇编语言中,nop指令是一个非常常见的指令,它的作用是让CPU暂停执行一定的时间。
二、nop指令的定义nop指令是汇编语言中的一个伪指令(pseudo-instruction),它不会被翻译成任何机器码,只是告诉汇编器在该位置生成一个空操作码。
nop指令通常被用来填充程序空间或者延迟执行。
三、nop指令的格式在x86架构中,nop指令有多种格式:1. nop:表示生成一个空操作码。
2. nopw:表示生成两个字节的空操作码。
3. nopd:表示生成四个字节的空操作码。
4. nopq:表示生成八个字节的空操作码。
四、nop指令的作用1. 填充程序空间:在程序开发过程中,为了保证代码段对齐或者调整代码段大小,需要插入一些无意义的代码来填充程序空间。
这时候可以使用nop指令来填充。
2. 延迟执行:有些时候需要让CPU暂停执行一定时间以等待外部设备的响应或者其他操作的完成。
这时候可以使用nop指令来延迟执行。
3. 调试程序:在调试程序时,有时需要在某个位置暂停执行以便于观察程序运行状态。
这时候可以在该位置插入nop指令来实现暂停。
五、nop指令的优化虽然nop指令是一个空操作码,但是它也会消耗CPU的时间和资源。
因此,在编写程序时需要避免无意义的nop指令的使用,以提高程序效率。
六、总结通过本文的介绍,我们了解了汇编语言中常见的nop指令。
它可以用来填充程序空间、延迟执行和调试程序等多种场景。
同时,在编写程序时也需要注意避免无意义的nop指令的使用,以提高程序效率。
汇编语言CMP指令CMP指令是汇编语言中常用的一种指令,用于比较两个操作数的大小。
该指令将两个操作数进行减法运算,并根据运算结果设置标志位,以供程序进行后续操作。
本文将对CMP指令的使用方法和注意事项进行详细介绍。
一、CMP指令的语法和功能在汇编语言中,CMP指令用于比较两个操作数的大小。
其常用的语法格式如下:CMP 源操作数,目的操作数其中,源操作数可以是寄存器、内存单元或立即数,而目的操作数通常为寄存器。
CMP指令的功能是将源操作数减去目的操作数,并根据减法运算的结果设置标志位。
具体来说,如果源操作数减去目的操作数等于零,则设置零标志位;如果源操作数小于目的操作数,则设置负标志位;如果源操作数大于目的操作数,则设置进位标志位。
二、CMP指令的使用方法1. 比较两个寄存器的内容CMP指令常用于比较两个寄存器的内容。
例如,下面的代码用于比较寄存器AX和寄存器BX的值:```MOV AX, 10h ; 将AX寄存器设置为10HMOV BX, 20h ; 将BX寄存器设置为20HCMP AX, BX ; 比较AX和BX的值```2. 比较寄存器和内存单元的内容除了比较寄存器之间的值,CMP指令还可以比较寄存器和内存单元的内容。
例如,下面的代码用于比较寄存器AX的值和内存单元[0100H]的值:```MOV AX, 10h ; 将AX寄存器设置为10HMOV CX, [0100H] ; 将CX寄存器设置为内存单元[0100H]的值CMP AX, CX ; 比较AX和CX的值```3. 比较寄存器和立即数此外,CMP指令还可以比较寄存器和立即数。
例如,下面的代码用于比较寄存器AX的值和立即数10H:```MOV AX, 10h ; 将AX寄存器设置为10HCMP AX, 10h ; 比较AX和立即数10H```三、CMP指令的注意事项在使用CMP指令时,需要注意以下几点:1. CMP指令仅影响标志位,不会影响操作数的值。
资料转移指令MOV 移动MOVC 程式记忆体移动MOVX 外部RAM和扩展I/O口与累加器A的数据传送指令PUSH 放入堆叠POP 由堆叠取回XCH 8位元交换XCHD 低4位元交换SWAP 高低4位元交换算术指令ADD 两数相加ADDC 两数相加再加CSUBB 两数相减再减CINC 加一指令DEC 减一指令MUL (MUL AB乘法指令仅此一条)相乘指令,所得的16位二进制数低8位存累加器A高8位存BDIV (DIV AB 除法指令仅此一条)相除指令,所得商存A,余数存BDA (DA A 只此一条指令)调整为十进数逻辑指令ANL做AND(逻辑与)运算ORL做OR(逻辑或)运算XRL 做(逻辑异或)运算CLR 清除为0CPL 取反指令RL 不带进位左环移RLC 带进位左环移RR 不带进位右环移RRC 带进位右环移控制转移类指令JC C=1时跳JNC C=0时跳JB 位元=1时跳JNB 位元=0时跳JBC 位元=1时跳且清除此位元LCALL 长调用子程序ACALL 绝对调用子程序RET 由副程式返回RETI 由中断副程式返回AJMP 绝对转移SJMP 相对转移JMP @A+DPTR 散转,相对DPTR的间接转移JZ A=0时跳JNZA 0时跳CJNE 二数比较,不相等时跳DJNZ 减一,不等於0时跳NOP 空操作位变量指令SETB 设定为1ORG 程序开始,规定程序的起始地址END 程序结束EQU 等值指令(先赋值后使用)例:SUM EQU 30HDB 定义字节指令DW 定义字内容DS 定义保留一定的存贮单元数目BIT 位地址符号指令例:SAM BIT P1.0 RET 子程序返回指令RETI 中断子程序返回指令$ 本条指令地址算术运算指令指令说明周期ADD A,Rn A←A+Rn 12ADD A,direct A←A+direct 12ADD A,@Ri A←A+Ri 12ADD A,#data A←A+data 12ADDC A,Rn A←A+Rn+C 12ADDC A,direct A←A+direct+C 12 ADDC A,@Ri A←A+Ri+C 12ADDC A,#data A←A+data+C 12SU BB A,Rn A←A-Rn-C 12SUBB A,direct A←A-direct-C 12 SUBB A,@Ri A←A-Ri-C 12SUBB A,#data A←A-data-C 12INC A A←A+1 12INC Rn Rn←Rn+1 12INC direct direct←direct+1 12INC @Ri @Ri←@Ri+1 12INC DPTR DPTR←DPTR+1 12DEC A A←A-1 12DEC Rn Rn←Rn-1 12DEC direct direct←direct-1 12DEC @Ri @Ri←@Ri-1 12MUL AB 两个无符号的8位数据相乘,其中高阶8位放入B缓存器,低阶8位则放入累积器ACC 24DIV AB 两个无符号的8位数据相除,把ACC 值除以B缓存器值,商数放回ACC,余数放在B 48DA A 累加器作十进制调整 48逻辑运算指令指令说明周期ANL A,Rn A←A and Rn 12ANL A,direct A←A and direct 12ANL A,@Ri A←A and Ri 12ANL A,#data A←A and data 12ANL direct,A direct←direct and A 12 ANL direct,#data direct←direct and data 24ORL A,Rn A←A or Rn 12ORL A,direct A←A or direct 12ORL A,Rn A←A or Rn 12ORL A,@Ri A←A or Ri 12ORL A,#data A←A or data 12ORL direct,A direct←direct or A 12 ORL direct,#data direct←direct or data 24XRL A,Rn A←A xor Rn 12XRL A,direct A←A xor direct 12XRL A,@Ri A←A xor Ri 12XRL A,#data A←A xor data 12XRL direct,A direct←direct xor A 12 XRL direct,#data dir ect←direct xor data 12CLR A 清除累加器 12CPL A 累加器反相 12RL A 累加器向左旋转 12RLC A 累加器和C左旋 12RR A 累加器向右旋转 12RRC A 累加器和C右旋 12SWAP A 累加器的高低四位互换 12数据转移指令指令说明周期MOV A,Rn A←Rn 12MOV A,direct A←direct 12MOV A,@Ri A←Ri 12MOV A,#data A←data 12MOV Rn,A Rn←A 12MOV Rn,direct Rn←direct 24MOV Rn,#data Rn←data 12MOV direct,A direct←A 12MOV direct,Rn direct←Rn 24MOV direct,direct direct←direct 24 MOV direct,@Ri direct←Ri 24MOV direct,#data direct←data 24MOV @Ri,A Ri←A 12MOV @Ri,direct Ri←direct 24MOV @Ri,#data Ri←data 12MOV DPTR,#data 16 Ri←16bit data 24 MOVC A,@A+DPTR A←程序内存的数据 24 MOVC A,@A+PC A←程序内存的数据 24 MOVX A,@Ri A←外部RAM的数据(8bit地址) 24MOVX A,@DPTR A←外部RAM的数据(16bit地址) 24MOVX @Ri,A 外部的RAM(8bit)←A 24 MOVX @DPTR,A 外部的RAM(16bit)←A 24 PUSH direc 推迭区←direct 24POP direc direct←堆栈区 24XCH A,Rn A和Rn互换 12XCH A,direct A和direct互换 12XCH A,@Ri A和Ri互换 12XCHD A,@Ri A和Ri的低四位互换 12位运算指令指令说明周期CLR C 清除进位旗标 12CLR bit 清除直接位 12SETB C 设定进位旗标 12SETB bit 设定直接位 12CPL C 进位旗标反相 12CPL bit 直接位反相 12ANL C,bit C←C and bit 24ANL C,/bit C←C and bit(反相) 24 ORL C,bit C←C or bit 24ORL C,/bit C←C or bit(反相) 24 MOV C,bit C←bit 12MOV bit,C bit←C 24JC rel 若C=1跳至rel 24JNC rel 若C=0跳至rel 24JB bit,rel 若bit=1跳至rel 24JNB bit,rel 若bit=0跳至rel 24JBC bit,rel 若bit=1跳至rel,且清除此位24程序跳跃指令指令说明周期ACALL addr11 绝对式子程序呼叫 24 LCALL addr16 远程子程序呼叫 24RET 从子程序返回 24RETI 从中断子程序返回 24AJMP addr11 绝对式跳跃 24LJMP addr16 远程跳跃 24SJMP rel 短程跳跃 24JMP @A+DPTR 间接跳跃 24JZ rel 若A=0跳至rel 24JNZ rel 若A不等于0跳至rel 24CJNE A,direct,rel 若A不等于direct跳至rel 24CJNE A,#data,rel 若A不等于data跳至rel 24CJNE Rn,#data,rel 若Rn不等于data跳至rel 24CJNE @Ri,#data,rel 若Ri不等于data跳至rel 24DJNZ Rn,rel Rn减1不等于0跳至rel 24 DJNZ direct,rel direct减1不等于0跳至rel 24NOP 没动作 12缩写符号说明缩写符号说明备注Rn 缓存器R0-R7direct 8bit内部数据存储器,包括1.内部数据存储器(00-7F)的地址2.特殊功能缓存器(80-FF)的地址,如P0,PSW,TMOD..等@Ri 由缓存器R0或R1所寻址的内部RAM数据#data 8bit常数#data 16 16bit常数addr 16 16bit的目的地址,可使跳跃指令跳跃64kaddr 11 11bit的目的地址,可使跳跃指令跳跃2krel 具正负号的8位地址偏移量,用于相对地址的跳跃bit 1个bit:只所有可以位寻址的位。
1.通用数据传送指令.MOV----> moveMOVSX---->extended move with sign data MOVZX---->extended move with zero data PUSH---->pushPOP---->popPUSHA---->push allPOPA---->pop allPUSHAD---->push all dataPOPAD---->pop all dataBSWAP---->byte swapXCHG---->exchangeCMPXCHG---->compare and changeXADD---->exchange and addXLAT---->translate2.输入输出端口传送指令.IN---->inputOUT---->output3.目的地址传送指令.LEA---->load effective addressLDS---->load DSLES---->load ESLFS---->load FSLGS---->load GSLSS---->load SS4.标志传送指令.LAHF---->load AH from flagSAHF---->save AH to flagPUSHF---->push flagPOPF---->pop flagPUSHD---->push dflagPOPD---->pop dflag二、算术运算指令ADD---->addADC---->add with carryINC---->increase 1AAA---->ascii add with adjustDAA---->decimal add with adjustSUB---->substractSBB---->substract with borrowDEC---->decrease 1NEC---->negativeCMP---->compareAAS---->ascii adjust on substractDAS---->decimal adjust on substractMUL---->multiplicationIMUL---->integer multiplicationAAM---->ascii adjust on multiplicationDIV---->divideIDIV---->integer divideAAD---->ascii adjust on divideCBW---->change byte to wordCWD---->change word to double wordCWDE---->change word to double word with sign to EAXCDQ---->change double word to quadrate word三、逻辑运算指令———————————————————————————————————————AND---->andOR---->orXOR---->xorNOT---->notTEST---->testSHL---->shift leftSAL---->arithmatic shift leftSHR---->shift rightSAR---->arithmatic shift rightROL---->rotate leftROR---->rotate rightRCL---->rotate left with carryRCR---->rotate right with carry四、串指令———————————————————————————————————————MOVS---->move stringCMPS---->compare stringSCAS---->scan stringLODS---->load stringSTOS---->store stringREP---->repeatREPE---->repeat when equalREPZ---->repeat when zero flagREPNE---->repeat when not equalREPNZ---->repeat when zero flagREPC---->repeat when carry flagREPNC---->repeat when not carry flag五、程序转移指令———————————————————————————————————————1>无条件转移指令(长转移)JMP---->jumpCALL---->callRET---->returnRETF---->return far2>条件转移指令(短转移,-128到+127的距离内)JAE---->jump when above or equalJNB---->jump when not belowJB---->jump when belowJNAE---->jump when not above or equalJBE---->jump when below or equalJNA---->jump when not aboveJG---->jump when greaterJNLE---->jump when not less or equalJGE---->jump when greater or equalJNL---->jump when not lessJL---->jump when lessJNGE---->jump when not greater or equalJLE---->jump when less or equalJNG---->jump when not greaterJE---->jump when equalJZ---->jump when has zero flagJNE---->jump when not equalJNZ---->jump when not has zero flagJC---->jump when has carry flagJNC---->jump when not has carry flagJNO---->jump when not has overflow flagJNP---->jump when not has parity flagJPO---->jump when parity flag is oddJNS---->jump when not has sign flagJO---->jump when has overflow flagJP---->jump when has parity flagJPE---->jump when parity flag is evenJS---->jump when has sign flag3>循环控制指令(短转移)LOOP---->loopLOOPE---->loop equalLOOPZ---->loop zeroLOOPNE---->loop not equalLOOPNZ---->loop not zeroJCXZ---->jump when CX is zeroJECXZ---->jump when ECX is zero4>中断指令INT---->interruptINTO---->overflow interruptIRET---->interrupt return5>处理器控制指令HLT---->haltWAIT---->waitESC---->escapeLOCK---->lockNOP---->no operationSTC---->set carryCLC---->clear carryCMC---->carry make changeSTD---->set directionCLD---->clear directionSTI---->set interruptCLI---->clear interrupt六、伪指令—————————————————————————————————————DW---->definw wordPROC---->procedureENDP---->end of procedureSEGMENT---->segmentASSUME---->assumeENDS---->end segmentEND---->end。
汇编跳转指令表汇编语言中的跳转指令主要用于控制程序的流程。
以下是一些常见的汇编语言跳转指令及其说明:1. JMP (Jump) - 无条件跳转。
无论目标地址是什么,都会跳转到该地址。
2. JE (Jump if Equal) - 如果两个操作数相等,则跳转。
常与比较指令(CMP)一起使用。
3. JNE (Jump if Not Equal) - 如果两个操作数不相等,则跳转。
常与比较指令(CMP)一起使用。
4. JG (Jump if Greater) - 如果第一个操作数大于第二个操作数,则跳转。
常与比较指令(CMP)一起使用。
5. JGE (Jump if Greater or Equal) - 如果第一个操作数大于或等于第二个操作数,则跳转。
常与比较指令(CMP)一起使用。
6. JL (Jump if Less) - 如果第一个操作数小于第二个操作数,则跳转。
常与比较指令(CMP)一起使用。
7. JLE (Jump if Less or Equal) - 如果第一个操作数小于或等于第二个操作数,则跳转。
常与比较指令(CMP)一起使用。
8. JA (Jump if Above) - 如果无符号运算的结果大于0,则跳转。
常与ADC指令一起使用。
9. JBE (Jump if Below or Equal) - 如果无符号运算的结果小于或等于0,则跳转。
常与SUBB指令一起使用。
10. JS (Jump if Signed) - 如果结果为负,则跳转。
常与ADC指令一起使用。
11. JO (Jump if Overflow) - 如果溢出发生,则跳转。
常与ADC、ADD或SUB指令一起使用。
12. JNP (Jump if Not Parity) - 如果结果没有奇偶校验位,则跳转。
常与ADC指令一起使用。
13. JPO (Jump if Parity) - 如果结果有奇偶校验位,则跳转。
常与ADC指令一起使用。
汇编语言(王爽版)用到的伪指令,指令等一寄存器(reg):AX,BX,CX,DX,ah,al,bh,bl,ch,cl,dh,dl,SI,DI,SP,BP,IP。
段寄存器(sreg):CS,SS,DS,ES。
1 CS——代码段寄存器(Code Segment Register),其值为代码段的段值;2 DS——数据段寄存器(Data Segment Register),其值为数据段的段值;3 SS——堆栈段寄存器(Stack Segment Register),其值为堆栈段的段值;4 ES——附加段寄存器(Extra Segment Register),其值为附加数据段的段值;5 BP为基指针(Base Pointer)寄存器,用它可直接存取堆栈中的数据;6 SP为堆栈指针(Stack Pointer)寄存器,用它只可访问栈顶。
7 寄存器AX和AL通常称为累加器(Accumulator),用累加器进行的操作可能需要更少时间。
累加器可用于乘、除、输入/输出等操作,它们的使用频率很高;8 寄存器BX称为基地址寄存器(Base Register)。
它可作为存储器指针来使用;9 寄存器CX称为计数寄存器(Count Register)。
在循环和字符串操作时,要用它来控制循环次数;在位操作中,当移多位时,要用CL来指明移位的位数;10 寄存器DX称为数据寄存器(Data Register)。
在进行乘、除运算时,它可作为默认的操作数参与运算,也可用于存放I/O的端口地址。
11 SI和DI称为变址寄存器(Index Register),它们主要用于存放存储单元在段内的偏移量,用它们可实现多种存储器操作数的寻址方式,为以不同的地址形式访问存储单元提供方便。
16位标志寄存器——共用了9个标志位,它们主要用来反映CPU的状态和运算结果的特征。
标志位的分布如下表所示。
15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0OF DF IF TF SF ZF AF PF CF 1、进位标志CF(Carry Flag)主要用来反映运算是否产生进位或借位。
MOV指令为双操作数指令,两个操作数中必须有一个是寄存器.MOV DST , SRC // Byte / Word执行操作: dst = src1.目的数可以是通用寄存器, 存储单元和段寄存器(但不允许用CS段寄存器).2.立即数不能直接送段寄存器3.不允许在两个存储单元直接传送数据4.不允许在两个段寄存器间直接传送信息PUSH入栈指令及POP出栈指令: 堆栈操作是以“后进先出”的方式进行数据操作.PUSH SRC //Word入栈的操作数除不允许用立即数外,可以为通用寄存器,段寄存器(全部)和存储器.入栈时高位字节先入栈,低位字节后入栈.POP DST //Word出栈操作数除不允许用立即数和CS段寄存器外, 可以为通用寄存器,段寄存器和存储器.执行POP SS指令后,堆栈区在存储区的位置要改变.执行POP SP 指令后,栈顶的位置要改变.XCHG(eXCHanG)交换指令: 将两操作数值交换.XCHG OPR1, OPR2 //Byte/Word执行操作: Tmp=OPR1 OPR1=OPR2 OPR2=Tmp1.必须有一个操作数是在寄存器中2.不能与段寄存器交换数据3.存储器与存储器之间不能交换数据.XLAT(TRANSLATE)换码指令: 把一种代码转换为另一种代码.XLAT (OPR 可选) //Byte执行操作: AL=(BX+AL)指令执行时只使用预先已存入BX中的表格首地址,执行后,AL中内容则是所要转换的代码.LEA(Load Effective Address) 有效地址传送寄存器指令LEA REG , SRC //指令把源操作数SRC的有效地址送到指定的寄存器中.执行操作: REG = EAsrc注: SRC只能是各种寻址方式的存储器操作数,REG只能是16位寄存器MOV BX , OFFSET OPER_ONE 等价于LEA BX , OPER_ONEMOV SP , [BX] //将BX间接寻址的相继的二个存储单元的内容送入SP中LEA SP , [BX] //将BX的内容作为存储器有效地址送入SP中LDS(Load DS with pointer)指针送寄存器和DS指令LDS REG , SRC //常指定SI寄存器。
汇编语言常用语句一览在学习和使用汇编语言时,熟悉常用的语句和指令是非常重要的。
本文将列举出一些汇编语言中常用的语句,以供参考和学习。
1. 数据传输指令MOV:将源数据移动到目标操作数中PUSH:将数据压入栈中POP:将栈顶元素弹出2. 算术运算指令ADD:将源数据与目标操作数相加SUB:将源数据与目标操作数相减INC:目标操作数自增1DEC:目标操作数自减1MUL:将源数据与目标操作数相乘DIV:将源数据与目标操作数相除3. 条件跳转指令JMP:无条件跳转到指定地址JZ/JNZ:根据零标志位是否为零跳转JE/JNE:根据相等标志位是否为真跳转JL/JLE:根据小于/小于等于标志位是否为真跳转JG/JGE:根据大于/大于等于标志位是否为真跳转4. 循环指令LOOP:循环指令,根据计数寄存器的值判断是否继续循环 INC/DEC + CMP + JNZ:结合使用,实现循环功能5. 标志位设置指令CMP:比较操作数,设置相应标志位TEST:与目标操作数进行按位与操作,设置相应标志位6. 子程序调用指令CALL:调用子程序RET:子程序返回指令7. 输入输出指令IN:从设备或端口读取数据OUT:向设备或端口输出数据8. 定义数据段指令DB:定义字节数据DW:定义字数据DD:定义双字数据9. 定义代码段指令SECTION:定义代码段10. 定义变量和常量指令DW:定义字变量或常量DD:定义双字变量或常量11. 定义字符串指令DB "Hello, World!",0:定义以0结尾的字符串12. 定义宏指令MACRO:定义宏ENDM:结束宏定义13. 定义过程指令PROC:定义过程ENDP:结束过程定义14. 调试指令INT 3:设置断点NOP:空操作以上是汇编语言中常用的语句一览。
通过熟悉和掌握这些语句,可以更好地编写汇编语言程序,并实现所需的功能。
希望本文对你的学习和使用汇编语言有所帮助。
汇编语⾔-移位指令基本概念移位操作指令:移位操作指令是⼀组经常使⽤的指令,属于汇编语⾔逻辑指令中的⼀部分,它包括移位指令(含算术移位指令、逻辑移位指令),循环移位指令(含带进位的循环移位指令),双精度移位指令三⼤类。
其功能为将⽬的操作数的所有位按操作符规定的⽅式移动1位或按寄存器CL规定的次数(0~255)移动,结果送⼊⽬的地址。
⽬的操作数是8位(或16位)的寄存器数据或存储器数据。
基本格式格式为:xxx oper1,CL/1移位次数只能是1或者存放在CL⾥⾯。
移位指令⼀、算术移位指令1、算术左移指令SAL功能:左移⼀次,最低位补0,最⾼位送⼊CF标志位,如图:意义:左移n次,等于x2的n次幂。
所以可⽤于有符号操作数做x2的n次幂运算。
2、算术右移指令SAR功能:右移⼀次,最⾼位保持不变,最低位送⼊CF标志位,如图:意义:右移n次,等于/2的n次幂。
所以可⽤于有符号操作数做/2的n次幂运算。
⼆、逻辑移位指令1、逻辑左移指令SHL功能:同SAL,如图:意义:同SAL2、逻辑右移指令SHR功能:右移⼀次,最⾼位补0.区别!最低位送⼊CF标志位。
如图:意义:⽤于实现⽆符号数/2的n次幂操作。
三、循环移位指令1、循环左移指令ROL功能:左移⼀次,左移前的最⾼位送⼊最低位以及CF.如图:2、循环右移指令ROR功能:右移⼀次,右移前的最低位送⼊最⾼位以及CF.如图:3、带进位的循环左移指令RCL功能:左移⼀次,左移前的最⾼位送⼊CF,CF的内容送⼊最低位.如图:4、带进位的循环右移指令RCR功能:右移⼀次,右移前的最低位送⼊CF,CF的内容送⼊最⾼位.如图:四、双精度移位指令1、双精度左移指令SHLD2、双精度右移指令SHRD。
8051系列单片机汇编语言指令速查表(汇编语言的111条指令)分类:程序语言编号指令名称指令助记符指令说明数据传送类指令1 一般传送 MOV A, #data 将立即数#data送累加器A2 MOV direct, #data 将立即数#data送片内RAM direct地址单元内3 Mov Rn, #data 将立即数#data送寄存器Rn4 Mov @Ri, #data 寄存器Ri内为RAM地址,将立即数#data送该地址单元内5 Mov direct2, direct1 将direct1地址单元的数据送 direct2地址单元内6 Mov direct, rn 将Rn的数据送 direct地址单元内7 Mov Rn, direct 将direct地址单元内的数据送Rn寄存器8 Mov direct, @Ri 寄存器Ri内为RAM地址,将该地址单元内的数据送direct 地址单元内9 Mov @Ri, direct 寄存器Ri内为RAM地址,将direct地址单元内的数据送该地址单元内10 Mov A, Rn 将寄存器Rn内的数据送累加器A11 Mov Rn, A 将累加器A内的数据送寄存器Rn12 Mov A, direct 将direct地址单元内的数据送累加器A13 Mov direct, A 将累加器A内的数据送direct地址单元内14 Mov A, @Ri 寄存器Ri内为RAM地址,将该地址单元内的数据送累加器A15 Mov @Ri , A 寄存器Ri内为RAM地址,将累加器A的数据送该地址单元内16 目的地址传送 Mov DPTR, #data16 将16位立即数送数据指针DPTR寄存器17 字节交换 SWAP A 累加器A高低4位数据交换18 XCH A, Rn 将累加器A数据和寄存器Rn内的数据交换19 XCH A, direct 将累加器A数据和direct地址单元内的数据交换20 XCH A, @Ri 寄存器Ri内为RAM地址,将该地址单元内的数据与累加器A的数据交换21 XCHD A, @Ri 寄存器Ri内为RAM地址,将该地址单元内的数据低4位与的低4位交换22 与外部RAM传送 MOVX @DPTR, A 将累加器A的数据送数据指针DPTR寄存器所指外部RAM地址单元内23 MOVX A , @DPTR 将DPTR寄存器所指外部RAM地址单元内的数据送累加器A24 MOVX A, @Ri 寄存器Ri内为片外RAM地址,将该地址单元内的数据送累加器A25 MOVX @Ri, A 寄存器Ri内为片外RAM地址,将该地址单元内的数据送累加器A26 与ROM传送 MOVC A, @A+DPTR A+DPTR构成ROM地址,将该地址内的数据送累加器A内27 MOVC A, @A+PC A+PC构成ROM地址,将该地址内的数据送累加器A内28 栈操作 PUSH direct 堆栈指针SP自加1后,将direct地址单元的数据压进堆栈,29 POP direct 堆栈的数据送direct地址单元中,后堆栈指针减1,算术运算指令30 加法指令 ADD A, Rn 将寄存器Rn与累加器A的数据相加后,结果保存到累加器A31 ADD A, direct 将direct地址单元内的数据与累加器A的数据相加后结果保存到累加器A32 ADD A, @Ri 寄存器Ri内位地址,将该地址单元内的数据与累加器A的数据相加后结果保存到累加器A33 ADD A, #data 将立即数与累加器A的数据相加后结果保存到累加器A34 带进位加法 ADDC A, Rn 将寄存器Rn与累加器A的数据相加,再加上进位标志内的值后,结果保存到累加器A35 ADDC A, direct 将direct地址单元内的数据与累加器A的数据相加,再加上进位标志内的值后,结果保存到累加器A36 ADDC A, @Ri 寄存器Ri内为RAM地址,将该地址单元内的数据与累加器A 的数据相加,再加上进位标志内的值后,结果保存到累加器A37 ADDC A, #data 将立即数与累加器A的数据相加,再加上进位标志内的值后结果保存到累加器A38 带借位减法 SUBB A, Rn 将与累加器A的数据减去寄存器Rn的数据,再减去进位标志内的值,结果保存到累加器A39 SUBB A, direct 将与累加器A的数据减去direct地址单元内的数据,再减去进位标志内的值,结果保存到累加器A40 SUBB A, @Ri 寄存器Ri内为RAM地址,将累加器A的数据减去该地址单元内的数据,再减去进位标志内的值后,结果保存到累加器A41 SUBB A, #data 将累加器A的数据减去立即数,再减去进位标志内的值后,结果保存到累加器A42 加1指令 INC A 累加器A的值自加143 INC Rn 寄存器Rn的值自加144 INC direct direct地址单元内值自加145 INC @Ri 寄存器Ri内为RAM地址,该地址单元内的值自加146 INC DPTR 数据指针寄存器DPTR内的值自加147 减1指令 DEC A 累加器A的值自减148 DEC Rn 寄存器Rn的值自减149 DEC direct direct地址单元内的值自减150 DEC @Ri 寄存器Ri内为RAM地址,该地址单元内的值自减151 乘法 MUL AB 累加器A与寄存器B内的值相乘,乘积的高8位保存在B寄存器,低8位保存在累加器A中52 除法 DIV AB 累加器A的值除以寄存器B的值,商保存在累加器A中,余数保存在B寄存器53 二-十进制调整 DA A 对累加器A的结果进行十进制调整逻辑运算指令54 逻辑与 ANL A, Rn 将累加器A的值和寄存器Rn的值进行与操作,结果保存到累加器A中55 ANL A, direct 将累加器A的值和direct地址单元内的值进行与操作,结果保存到累加器A中56 ANL A, @Ri 寄存器Ri内为RAM地址,将累加器A的值和该地址单元内的值进行与操作,结果保存到累加器A中57 ANL A, #data 将累加器A的值和立即数进行与操作,结果保存到累加器A 中58 ANL direct, A 将累加器A的值和direct地址单元内的值进行与操作,结果保存到direct地址单元内59 ANL direct, #data 将立即数和direct地址单元内的值进行与操作,结果保存到direct地址单元内60 逻辑或 ORL A, Rn 将累加器A的值和寄存器Rn的值进行或操作,结果保存到累加器A中61 ORL A, direct 将累加器A的值和direct地址单元内的值进行或操作,结果保存到累加器A中62 ORL A, @Ri 寄存器Ri内为RAM地址,将累加器A的值和该地址单元内的值进行或操作,结果保存到累加器A中63 ORL A, #data 将累加器A的值和立即数进行或操作,结果保存到累加器A 中64 ORL direct, A 将累加器A的值和direct地址单元内的值进行或操作,结果保存到direct地址单元内65 ORL direct, #data 将立即数和direct地址单元内的值进行或操作,结果保存到direct地址单元内66 逻辑异或 XRL A, Rn 将累加器A的值和寄存器Rn的值进行异或操作,结果保存到累加器A中67 XRL A, direct 将累加器A的值和direct地址单元内的值进行异或操作,结果保存到累加器A中68 XRL A, @Ri 寄存器Ri内为RAM地址,将累加器A的值和该地址单元内的值进行异或操作,结果保存到累加器A中69 XRL A, #data 将累加器A的值和立即数进行异或操作,结果保存到累加器A 中70 XRL direct, A 将累加器A的值和direct地址单元内的值进行异或操作,结果保存到direct地址单元内71 XRL direct, #data 将立即数和direct地址单元内的值进行异或操作,结果保存到direct地址单元内72 按位取反 CPL A 累加器A的值按位取反73 累加器清零 CLR A 累加器A清074 逻辑右移 RR A 累加器A的值循环右移1位75 逻辑左移 RL A 累加器A的值循环左移1位76 带进位右移 RRC A 累加器A的值带进位循环右移1位77 带进位左移 RLC A 累加器A的值带进位循环左移1位控制转移指令78 无条件转移 SJMP rel rel为地址偏移量,PC加2后的地址加上rel作为目标地址,程序跳到目标地址继续运行79 AJMP addr11(a10- a0) addr11为11位地址,PC加2后的地址高5位与指令中的低11位地址构成目标地址,程序跳到目标地址继续运行80 LJMP addr16 将addr16的16位地址送程序计数器PC,使机器执行下一条指令时无条件转移到addr16处执行程序81 JMP @A+DPTR 目标地址的基地址放在DPTR中,目标地址对基地址的偏移量放在累加器A中,它们相加构成目标地址82 条件转移 JZ rel If(累加器A=0)则PC加2再加上rel作为目标地址83 JNZ rel If(累加器A!=0)则PC加2再加上rel作为目标地址84 CJNE A, direct, rel If(累加器A!= direct地址单元的值)则PC加2再加上rel作为目标地址85 CJNE A, #data, rel If(累加器A!= 立即数)则PC加2再加上rel作为目标地址86 CJNE Rn, #data, rel If(寄存器Rn的值!= 立即数)则PC加2再加上rel 作为目标地址87 CJNE @Ri, #data, rel 寄存器Ri内为RAM地址,If(该地址单元的值!= 立即数)则PC加2再加上rel作为目标地址88 循环转移 DJNZ Rn, rel 寄存器Rn的值减1后,If(寄存器Rn的值!=0)则PC加2再加上rel作为目标地址89 DJNZ direct, rel Direct地址单元的值减1后,If(该值!=0)则PC加3再加上rel作为目标地址90 布尔条件转移 JC rel If(CY=1)则PC加2再加上rel作为目标地址91 JNC rel If(CY=0)则PC加2再加上rel作为目标地址92 JB bit, rel If(bit位=1)则PC加3再加上rel作为目标地址93 JNB bit, rel If(bit位=0)则PC加3再加上rel作为目标地址94 JBC bit, rel If(bit位=1)则PC加3再加上rel作为目标地址,且bit位清095 调用指令 ACALL addr11 addr11为11位地址,PC加2后的地址PUSH进堆栈,再将PC的地址高5位与指令中的低11位地址构成目标地址,程序跳到目标地址继续运行96 LCALL addr16 PC加3后的地址PUSH进堆栈,再将16位地址送PC作为目标地址,程序跳到目标地址继续运行97 返回指令 RET 子程序返回指令,把堆栈中的地址恢复到PC中使程序回到调用处98 RETI 中断程序返回指令,把堆栈中的地址恢复到PC中使程序回到调用处99 空操作 NOP 空操作位操作指令100 布尔传送 MOV C, bit 将bit位地址中的值送PSW中的进位标志位CY101 MOV bit, C 将PSW中的进位标志位CY的值送bit位地址中102 位清0 CLR C 将进位标志位CY清0103 位清0 CLR bit 将bit位地址内清0104 位置1 SETB C 将进位标志位CY置1105 SETB bit 将bit位地址内置1106 位与 ANL C, bit 将Cy和bit位地址中的值进行与操作后,结果送Cy 107 ANL C, /bit bit位地址中的值取反后再与Cy进行与操作,结构送Cy108 位或 ORL C, bit 将Cy和bit位地址中的值进行或操作后,结果送Cy109 ORL C, /bit bit位地址中的值取反后再与Cy进行或操作,结构送Cy 110 位取反 CPL C 将Cy取反111 CPL bit 将bit位地址的值取反说明:1)Ri, Rn指当前工作寄存器,i,n = 0 – 7,当前工作寄存器由程序状态字寄存器PSW的2个位RS1, RS0决定。
汇编语言指令速查表指令集是计算机中执行指令的一组规范。
在汇编语言中,使用指令来编写具体的程序。
为了方便程序员查找和运用各种指令,制作一份汇编语言指令速查表是非常有必要的。
在本文中,我将提供一份完整的汇编语言指令速查表,帮助读者快速查找和了解汇编语言指令。
以下是一份汇编语言指令速查表,按照指令的功能进行分类。
1. 数据传送指令MOV:将数据从源操作数移动到目标操作数。
XCHG:交换两个操作数的值。
2. 运算指令ADD:将源操作数的值与目标操作数的值相加,并将结果存储到目标操作数中。
SUB:将目标操作数的值减去源操作数的值,并将结果存储到目标操作数中。
MUL:将源操作数的值与目标操作数的值相乘,并将结果存储到目标操作数中。
DIV:将目标操作数的值除以源操作数的值,并将商存储到目标操作数中。
3. 逻辑运算指令AND:对源操作数和目标操作数进行逻辑与运算,并将结果存储到目标操作数中。
OR:对源操作数和目标操作数进行逻辑或运算,并将结果存储到目标操作数中。
XOR:对源操作数和目标操作数进行逻辑异或运算,并将结果存储到目标操作数中。
NOT:对目标操作数进行逻辑非运算,并将结果存储到目标操作数中。
4. 分支指令JMP:无条件跳转到指定的地址。
JZ:如果零标志位为1,则跳转到指定的地址。
JNZ:如果零标志位为0,则跳转到指定的地址。
JE:如果相等标志位为1,则跳转到指定的地址。
JNE:如果相等标志位为0,则跳转到指定的地址。
5. 循环指令LOOP:根据计数器的值,循环执行指定的代码块。
LOPZ:如果零标志位为1,则循环执行指定的代码块。
LOPE:如果相等标志位为1,则循环执行指定的代码块。
6. 存储器访问指令MOV:将数据从寄存器移动到存储器中,或将数据从存储器移动到寄存器中。
PUSH:将数据压入堆栈。
POP:将数据从堆栈中弹出。
7. 程序调用指令CALL:调用指定地址处的子程序。
RET:从调用的子程序返回。
8. I/O指令IN:从外部设备读取数据。
汇编语言x86汇编指令集大全汇编语言是计算机体系结构学科中的重要内容之一,它可以直接操作计算机硬件,实现对机器指令的精确控制。
而x86汇编则是汇编语言中最常用的一种,它广泛应用于各类个人电脑和服务器等计算设备中。
x86汇编指令集是汇编语言中的核心,掌握其基本指令对于开发高效的汇编程序至关重要。
本文将介绍x86汇编指令集的各个方面,包括数据传输指令、算术运算指令、逻辑运算指令、分支控制指令以及其他常用指令等内容,以帮助读者全面理解和掌握x86汇编语言。
一、数据传输指令数据传输指令是汇编语言中最基本的指令之一,用于实现数据在寄存器、内存和I/O端口之间的传递。
常见的数据传输指令包括MOV、XCHG、PUSH和POP等。
MOV指令用于将数据从一个位置传送到另一个位置,可以将数据从内存中传送到寄存器,也可以将数据从寄存器传送到内存。
例如,MOV AX, BX表示将寄存器BX中的数据传送到寄存器AX中。
XCHG指令用于交换两个操作数的值,例如,XCHG AX, BX表示交换寄存器AX和BX中的数据。
PUSH指令将数据推入堆栈,POP指令从堆栈中弹出数据。
这两个指令常用于函数调用和局部变量的保存与恢复。
二、算术运算指令算术运算指令用于执行各种数值计算操作,包括加法、减法、乘法、除法以及取模等。
常见的算术运算指令包括ADD、SUB、MUL、DIV和IMUL等。
ADD指令用于进行加法运算,可以将两个操作数相加,并将结果保存在目标操作数中。
例如,ADD AX, BX表示将寄存器BX中的值加到寄存器AX中。
SUB指令用于进行减法运算,可以将目标操作数减去源操作数,并将结果保存在目标操作数中。
MUL指令用于进行无符号数的乘法运算,可以将一个操作数与寄存器中的值相乘,并将结果保存在一对寄存器中。
DIV指令用于进行无符号数的除法运算,可以将寄存器中的值除以一个操作数,并将商保存在一个寄存器中,余数保存在另一个寄存器中。
IMUL指令用于进行有符号数的乘法运算,功能与MUL指令类似,但结果为有符号数。
一、数据传输指令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 累加器, )OUT I/O端口输出. ( 语法: OUT ,累加器)输入输出端口由立即方式指定时, 其范围是0-255; 由寄存器DX 指定时, 其范围是0-65535.3. 目的地址传送指令.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.4. 标志传送指令.LAHF标志寄存器传送,把标志装入AH.SAHF标志寄存器传送,把AH内容装入标志寄存器. PUSHF标志入栈. POPF标志出栈. PUSHD32位标志入栈. POPD32位标志出栈.二、算术运算指令───────────────────────────────────────ADD加法.ADC带进位加法.INC加1.AAA加法的ASCII码调整. DAA加法的十进制调整. SUB减法.SBB带借位减法.DEC减1. NEC求反(以0 减之).CMP比较.(两操作数作减法,仅修改标志位,不回送结果). AAS减法的ASCII码调整.DAS减法的十进制调整.MUL无符号乘法.IMUL整数乘法.以上两条,结果回送AH和AL(字节运算),或DX和AX(字运算).AAM乘法的ASCII码调整.DIV无符号除法.IDIV整数除法.以上两条,结果回送: 商回送AL,余数回送AH, (字节运算); 或商回送AX,余数回送DX, (字运算).AAD除法的ASCII码调整. CBW字节转换为字. (把AL中字节的符号扩展到AH 中去)CWD字转换为双字. (把AX中的字的符号扩展到DX 中去)CWDE字转换为双字. (把AX中的字符号扩展到EAX 中去)CDQ双字扩展.(把EAX中的字的符号扩展到EDX中去)三、逻辑运算指令───────────────────────────────────────AND与运算.OR或运算.XOR异或运算.NOT取反.TEST测试.(两操作数作与运算,仅修改标志位,不回送结果).SHL逻辑左移.SAL算术左移.(=SHL)SHR逻辑右移.SAR算术右移.(=SHR) ROL循环左移.ROR循环右移.RCL通过进位的循环左移.RCR通过进位的循环右移.以上八种移位指令,其移位次数可达255次.移位一次时, 可直接用操作码.如SHL AX,1. 移位>1次时, 则由寄存器CL给出移位次数. 如MOV CL,04SHL AX,CL四、串指令───────────────────────────────────────DS:SI源串段寄存器:源串变址. ES:DI目标串段寄存器:目标串变址. CX重复次数计数器.AL/AX扫描值. D标志0表示重复操作中SI和DI应自动增量; 1表示应自动减量.Z标志用来控制扫描或比较操作的结束.MOVS串传送.( MOVSB传送字符. MOVSW传送字.MOVSD传送双字. )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时重复.五、程序转移指令───────────────────────────────────────1>无条件转移指令(长转移)JMP无条件转移指令CALL过程调用RET/RETF过程返回.2>条件转移指令(短转移,-128到+127的距离内) ( 当且仅当(SF XOR OF)=1时,OP1JA/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清中断允许位.六、伪指令───────────────────────────────────────DW定义字(2字节). PROC定义过程. ENDP过程结束. SEGMENT定义段. ASSUME建立段寄存器寻址. ENDS段结束.END程序结束.第一、数据寄存器(Data Register)EAX 累加寄存器(accumulator), 常用于运算;用来存放操作数,所有的I/O指令用之与外界设备传送数据。