汇编语言常见指令

合集下载

汇编语言常见指令

汇编语言常见指令

汇编语言常见指令汇编语言常见指令“PTR”操作符:强制类型转换MOV BYTE PTR [BX], 20H;1B立即数20H送DS:[BX]MOV WORD PTR [BX], 20H;立即数20H送DS:[BX],;00H送DS:[BX+1]2.LEA(Load Effective Address)设:变量X的偏移地址为1020H , (BP)=0020H 执行指令后:LEA DX, XLEA BX, [BP]; 执行后, (DX) = 1020H; 执行后, (BX) = 0020H3.地址传送指令LDS,LESLDS REG16, MEM ; 从存储器取出4B,送入REG16和DSLES REG16, MEM ; 从存储器取出4B,送入REG16和ES4.符号扩展指令CBW,CWDCBW ;将AL寄存器内容符号位扩展到AH CWD ;将AX寄存器内容符号位扩展到DX设:(AX)= 8060H,(DX)=1234H执行下列指令后CBW;(AX)= 0060H设:(AX)= 8060H,(DX)=1234H执行下列指令后CWD;(DX)= 0FFFFH,(AX)= 8060H 5.交换指令XCHG例如,(AX)= 5678H执行下面指令后XCHG A H, AL;(AX)= 7856H6.换码指令XLATXLAT ;AL←DS: [BX+AL]表格的首地址事先存放在内存逻辑地址DS: BX 中,AL的内容是相对于表格的位移量,把对应内存的内容取出放在AL寄存器。

7.逻辑运算符SHR(右移)SHL(左移)AND(与)OR(或)XOR(异或)NOT(取反8.关系运算符关系运算符用于两个数的比较,结果为“真(-1)”或“假(0)”GT(>)GE(>=)LT(<)LE(<=)EQ(=)NE(≠)9.地址运算符SEG 名称取地址表达式所在段的段基址OFFSET 名称取地址表达式的偏移地址10.类型操作符TYPE:取每个变量的字节数LENGTH:取变量定义了多少个取变量占用的字节总数11.加法指令(1)ADD(Addition):加法指令格式:ADD dest,src功能:dest ←dest + srcdest(目的操作数):8/16位的寄存器/存储器操作数src(源操作数):与目的操作数同类型的寄存器/存储器/立即数例:A DD AX, SI ; AX←(AX)+(SI),16位运算ADD X, 3 ; X←(X)+3, 运算位数由X的类型确定ADD [BX], DX ; DS:[BX]←DS:[BX]+DX, 16位运算说明:状态标志CF, OF, ZF, SF, PF, AF按照运算结果被刷新;(2)ADC(Addition with Carry):带进位的加法指令格式:ADC dest,src功能:dest←dest+src+CFdest(目的操作数):8/16位的寄存器/存储器src(源操作数):与目的操作数同类型的寄存器/存储器/立即数说明:状态标志CF, OF, ZF, SF, PF, AF按照运算结果被刷新;主要用于对数据分段相加时高位的加法运算。

汇编语言常用指令汇总持续更新

汇编语言常用指令汇总持续更新

汇编语言常用指令汇总持续更新汇编语言常用指令汇总汇编语言是一种低级编程语言,用于与计算机硬件进行直接交互。

熟悉汇编语言的常用指令对于理解计算机底层原理和进行底层编程非常重要。

本文将对汇编语言常用指令进行汇总,并持续更新。

1. 数据传输指令:- MOV:用于将数据从一个位置复制到另一个位置。

- LXI:用于将双字节立即数加载到指定的寄存器对中。

- LDA:用于将累加器加载到内存地址中的数据。

- STA:用于将累加器中的数据存储到指定的内存地址中。

2. 算术运算指令:- ADD:用于将累加器的内容与给定的寄存器或内存位置中的数据相加。

- SUB:用于从累加器中减去给定的寄存器或内存位置中的数据。

- INR:用于将给定的寄存器或内存位置中的数据增加1。

- DCR:用于将给定的寄存器或内存位置中的数据减少1。

3. 逻辑运算指令:- AND:用于将累加器的内容与给定的寄存器或内存位置中的数据进行逻辑与操作。

- OR:用于将累加器的内容与给定的寄存器或内存位置中的数据进行逻辑或操作。

- XOR:用于将累加器的内容与给定的寄存器或内存位置中的数据进行逻辑异或操作。

- NOT:用于对累加器的内容进行逻辑非操作。

4. 控制指令:- JMP:用于无条件转移到指定的内存地址。

- JZ:在累加器为零时,转移到指定的内存地址。

- JC:在进位标志为1时,转移到指定的内存地址。

- CALL:用于调用子程序。

5. 栈操作指令:- PUSH:用于将给定的寄存器或数据压入栈中。

- POP:从栈中弹出数据并存储到给定的寄存器中。

6. 输入输出指令:- IN:从外部设备读取数据,并存储到累加器中。

- OUT:将累加器中的数据发送到外部设备。

以上仅是汇编语言中常用指令的一小部分,还有许多其他指令可用于执行更复杂的任务。

在实际的汇编语言程序中,这些指令通常会与标签、变量和宏指令一起使用。

总结:汇编语言常用指令汇总了数据传输、算术运算、逻辑运算、控制、栈操作和输入输出等方面的指令。

常用汇编指令

常用汇编指令

常用汇编指令汇编语言是一种低级机器语言的抽象表示,通过使用汇编指令可以编写出与硬件相关的程序。

在计算机科学领域中,汇编指令是非常重要的,是理解计算机底层原理和实现的关键。

本文将介绍一些常用的汇编指令,以帮助读者更好地理解和应用这些指令。

一、数据传输指令1. MOV指令:MOV指令用于将数据从一个位置复制到另一个位置。

例如,MOV AX, BX将寄存器BX的内容复制到AX中。

2. LEA指令:LEA指令用于将内存地址加载到寄存器中。

例如,LEA BX, [SI+10]将[S1+10]的内存地址加载到寄存器BX中。

3. PUSH指令:PUSH指令用于将数据压入栈中。

例如,PUSH AX将AX中的数据压入栈中。

4. POP指令:POP指令用于从栈中弹出数据。

例如,POP BX将栈中的数据弹出到BX中。

二、算术运算指令1. ADD指令:ADD指令用于将两个操作数相加,并将结果存储在目标操作数中。

例如,ADD AX, BX将BX的值加到AX中。

2. SUB指令:SUB指令用于将源操作数的值从目标操作数中减去,并将结果存储在目标操作数中。

例如,SUB AX, BX从AX中减去BX的值。

3. MUL指令:MUL指令用于将源操作数与累加器中的值相乘,并将结果存储在累加器中。

例如,MUL BX将累加器的值与BX相乘。

4. DIV指令:DIV指令用于将累加器的值除以源操作数,并将商存储在累加器中,余数存储在另一个寄存器中。

例如,DIV BX将累加器的值除以BX。

三、逻辑运算指令1. AND指令:AND指令用于对两个操作数进行逻辑与运算,并将结果存储在目标操作数中。

例如,AND AX, BX将AX与BX进行逻辑与操作。

2. OR指令:OR指令用于对两个操作数进行逻辑或运算,并将结果存储在目标操作数中。

例如,OR AX, BX将AX与BX进行逻辑或操作。

3. NOT指令:NOT指令用于对操作数进行逻辑非运算,并将结果存储在目标操作数中。

汇编的基本常用指令

汇编的基本常用指令

汇编的基本常用指令汇编语言是一种底层的程序设计语言,主要用于编写机器码指令。

以下是一些常用的汇编指令:1. MOV:将数据从一个位置复制到另一个位置。

2. ADD:将两个操作数相加,并将结果存储在目的操作数中。

3. SUB:将第二个操作数从第一个操作数中减去,并将结果存储在目的操作数中。

4. INC:将一个操作数的值增加1。

5. DEC:将一个操作数的值减少1。

6. CMP:比较两个操作数的值,并将结果影响到标志寄存器中。

7. JMP:无条件跳转到指定的代码位置。

8. JZ / JE:当指定的条件成立时,跳转到指定的代码位置(零标志或相等标志)。

9. JNZ / JNE:当指定的条件不成立时,跳转到指定的代码位置(非零标志或不相等标志)。

10. JL / JB:当源操作数小于目的操作数时,跳转到指定的代码位置(小于标志或借位标志)。

11. JG / JA:当源操作数大于目的操作数时,跳转到指定的代码位置(大于标志或进位标志)。

12. CALL:调用一个子程序或函数。

13. RET:返回子程序或函数的调用处。

14. NOP:空操作,用于占位或调整程序代码的位置。

15. HLT:停止运行程序,将CPU置于停机状态。

这里只列举了一些基本的汇编指令,实际上汇编语言有更多更复杂的指令,具体使用哪些指令取决于所使用的汇编语言和目标处理器的指令集架构。

继续列举一些常用的汇编指令:16. AND:将两个操作数进行按位与运算,并将结果存储在目的操作数中。

17. OR:将两个操作数进行按位或运算,并将结果存储在目的操作数中。

18. XOR:将两个操作数进行按位异或运算,并将结果存储在目的操作数中。

19. NOT:对一个操作数的每一位进行取反操作。

20. SHL / SAL:将一个操作数的每一位向左移动指定的位数。

对于无符号数,使用SHL指令;对于带符号数,使用SAL指令。

21. SHR:将一个操作数的每一位向右移动指定的位数,高位空出的位使用0填充。

汇编语言基本指令详解

汇编语言基本指令详解

汇编语言基本指令详解在计算机科学和计算机工程领域,汇编语言是一种计算机底层编程语言,用于直接控制计算机硬件。

它是机器语言的文本形式,使用符号和助记符来代表机器指令,相对于高级编程语言来说更加底层。

汇编语言基本指令是使用汇编语言进行编程时必不可少的内容。

下面将详细介绍汇编语言中常用的基本指令。

1. 数据传送指令数据传送指令用于在寄存器之间传递数据,常见的指令有MOV、ADD、SUB、MUL等。

MOV指令用于将数据从一个位置传送到另一个位置,格式为MOV 目标操作数, 源操作数。

例如,MOV AX, BX可以将BX的值传送给AX。

ADD指令用于将两个操作数相加,并将结果保存到目标操作数中。

格式为ADD 目标操作数, 源操作数。

例如,ADD AX, BX可以将AX与BX的值相加,并将结果保存在AX中。

SUB指令用于将源操作数的值从目标操作数中减去,并将结果保存到目标操作数中。

格式为SUB 目标操作数, 源操作数。

例如,SUB AX, BX可以将BX的值从AX中减去,并将结果保存在AX中。

MUL指令用于将两个操作数相乘,并将结果保存到目标操作数中。

格式为MUL 目标操作数, 源操作数。

例如,MUL AX, BX可以将AX与BX的值相乘,并将结果保存在AX中。

2. 算术逻辑指令算术逻辑指令用于进行各种算术和逻辑运算,例如加法、减法、乘法、除法、与、或、非等。

ADD指令在前面已经提到,用于将两个操作数相加。

SUB指令在前面已经提到,用于将源操作数的值从目标操作数中减去。

MUL指令在前面已经提到,用于将两个操作数相乘。

DIV指令用于将目标操作数除以源操作数,并将商保存到目标操作数,余数保存在DX中。

格式为DIV 操作数。

例如,DIV BX可以将AX的值除以BX,并将商保存在AX中,余数保存在DX中。

AND指令用于对两个操作数进行按位与运算,并将结果保存到目标操作数中。

格式为AND 目标操作数, 源操作数。

例如,AND AX,BX可以将AX与BX的值按位与,并将结果保存在AX中。

汇编常用指令

汇编常用指令

汇编常用指令汇编语言是计算机底层的一种编程语言,通过编写汇编指令可以直接控制机器的硬件和内存。

在使用汇编语言编写程序时,掌握一些常用指令是非常重要的。

本文将介绍一些常用的汇编指令,帮助读者更好地理解和应用汇编语言。

一、数据传输指令数据传输指令用于在寄存器和内存之间传输数据,包括将数据从内存加载到寄存器中,以及将寄存器中的数据存储到内存中。

常用的数据传输指令包括: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"表示将BX的值加到AX中。

2. SUB:将第一个操作数减去第二个操作数。

例如,"SUB AX, BX"表示用BX的值减去AX,并将结果存储到AX中。

3. MUL:将两个操作数相乘。

例如,"MUL AX, BX"表示将AX乘以BX,并将结果存储到一组寄存器中。

4. DIV:将第一个操作数除以第二个操作数。

例如,"DIV AX, BX"表示用AX的值除以BX,并将商存储到一组寄存器中。

5. AND:对两个操作数执行逻辑与运算。

例如,"AND AX, BX"表示将AX和BX进行逻辑与操作。

6. OR:对两个操作数执行逻辑或运算。

汇编指令大全(有注释)_IT计算机_专业资料

汇编指令大全(有注释)_IT计算机_专业资料

汇编指令大全(有注释)_IT计算机_专业资料汇编指令大全(有注释)为了方便开发者理解和使用汇编语言,本文汇编指令大全提供了对常用指令的详细注释。

汇编语言是一种低级编程语言,直接操作计算机的硬件和寄存器。

掌握汇编语言对于理解计算机底层原理和优化程序性能至关重要。

下面列举了一些常用的汇编指令,以供参考。

1. MOV指令:用于将一个数据从一个位置复制到另一个位置。

可以在寄存器和内存之间传输数据。

示例:MOV AX, 10h ; 将数据10h复制到寄存器AX中MOV [BX], AX ; 将寄存器AX中的数据复制到内存地址BX指向的位置2. ADD指令:用于将两个数据相加,并将结果存储在指定的位置。

示例:ADD AX, BX ; 将寄存器AX和BX中的数据相加,并将结果保存在AX中ADD [BX], CX ; 将内存地址BX指向的数据与寄存器CX中的数据相加,并将结果保存在内存地址BX指向的位置3. SUB指令:用于将两个数据相减,并将结果存储在指定的位置。

示例:SUB AX, BX ; 将寄存器AX的数据减去BX的数据,并将结果保存在AX中SUB [BX], CX ; 将内存地址BX指向的数据减去寄存器CX的数据,并将结果保存在内存地址BX指向的位置4. INC指令:用于将指定位置的数据加1。

示例:INC AX ; 将寄存器AX的数据加1INC [BX] ; 将内存地址BX指向的数据加15. DEC指令:用于将指定位置的数据减1。

示例:DEC AX ; 将寄存器AX的数据减1DEC [BX] ; 将内存地址BX指向的数据减16. JMP指令:用于无条件跳转到指定的代码位置。

示例:JMP label1 ; 无条件跳转到标签label1处JMP 100h ; 无条件跳转到内存地址100h处7. CMP指令:用于比较两个数据的大小,并根据比较结果设置条件码寄存器。

示例:CMP AX, BX ; 比较寄存器AX和BX的数据大小,并设置条件码寄存器CMP [BX], CX ; 比较内存地址BX指向的数据和寄存器CX的数据大小,并设置条件码寄存器8. JE指令:用于在两个数据相等时跳转到指定的代码位置。

汇编常用指令

汇编常用指令

汇编常用指令1. 前言汇编语言是一种低级别的计算机语言,它是由一些指令组成的。

指令是一条计算机执行的命令,从基本上讲,这些指令代表着标准的操作,例如加、减、乘、除、移位和比较等。

汇编语言可以通过编写程序来控制一个计算机的行为,这些程序通常被称为汇编程序。

本文将介绍汇编语言中一些常用的指令。

2. 数据传送指令数据传送指令是汇编语言中最基本的指令之一,它主要用来将数据从一个位置传送到另一个位置。

在汇编语言中,数据传送指令通常使用MOV语句来实现。

下面是一些常用的数据传送指令:- MOV AX, BX:将BX中存储的数据传送到AX中。

- MOV AX, [BX]:将BX中存储的地址所指向的数据传送到AX中。

- MOV [BX], AX:将AX中存储的数据传送到BX所指向的地址中。

3. 算术运算指令算术运算指令主要用来执行各种数学运算,例如加法、减法、乘法和除法等操作。

下面是一些常用的算术运算指令:- ADD AX, BX:将BX中存储的数据与AX中存储的数据相加,并将结果存储在AX中。

- SUB AX, BX:将BX中存储的数据从AX中存储的数据中减去,并将结果存储在AX中。

- MUL BX:将AX中存储的数据与BX中存储的数据相乘,并将结果存储在AX中。

- DIV BX:将AX中存储的数据除以BX中存储的数据,并将结果存储在AX和DX中。

4. 位运算指令位运算是一种在二进制数字级别上的运算,它可以执行各种位操作,例如AND、OR、XOR和NOT等操作。

下面是一些常用的位运算指令:- AND AX, BX:将BX中存储的数据与AX中存储的数据按位进行AND运算,并将结果存储在AX中。

- OR AX, BX:将BX中存储的数据与AX中存储的数据按位进行OR 运算,并将结果存储在AX中。

- XOR AX, BX:将BX中存储的数据与AX中存储的数据按位进行XOR运算,并将结果存储在AX中。

- NOT AX:将AX中存储的数据按位进行取反操作。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

‚PTR‛操作符:强制类型转换MOV BYTE PTR [BX], 20H;1B立即数20H送DS:[BX]MOV WORD PTR [BX], 20H;立即数20H送DS:[BX],;00H送DS:[BX+1]2.LEA(Load Effective Address)设:变量X的偏移地址为1020H , (BP)=0020H执行指令后:LEA DX, XLEA BX, [BP]; 执行后, (DX) = 1020H; 执行后, (BX) = 0020H3.地址传送指令LDS,LESLDS REG16, MEM ; 从存储器取出4B,送入REG16和DS LES REG16, MEM ; 从存储器取出4B,送入REG16和ES 4.符号扩展指令CBW,CWDCBW ;将AL寄存器内容符号位扩展到AHCWD ;将AX寄存器内容符号位扩展到DX设:(AX)= 8060H,(DX)=1234H执行下列指令后CBW;(AX)= 0060H设:(AX)= 8060H,(DX)=1234H执行下列指令后CWD;(DX)= 0FFFFH,(AX)= 8060H5.交换指令XCHG例如,(AX)= 5678H执行下面指令后XCHG AH, AL;(AX)= 7856H6.换码指令XLATXLAT ;AL←DS: [BX+AL]表格的首地址事先存放在内存逻辑地址DS: BX中,AL的内容是相对于表格的位移量,把对应内存的内容取出放在AL寄存器。

7.逻辑运算符SHR(右移)SHL(左移)AND(与)OR(或)XOR(异或)NOT(取反8.关系运算符关系运算符用于两个数的比较,结果为‚真(-1)‛或‚假(0)‛GT(>)GE(>=)LT(<)LE(<=)EQ(=)NE(≠)9.地址运算符SEG 名称取地址表达式所在段的段基址OFFSET 名称取地址表达式的偏移地址10.类型操作符TYPE:取每个变量的字节数LENGTH:取变量定义了多少个SIZE:取变量占用的字节总数11.加法指令(1)ADD(Addition):加法指令格式:ADD dest,src功能:dest ←dest + srcdest(目的操作数):8/16位的寄存器/存储器操作数src(源操作数):与目的操作数同类型的寄存器/存储器/立即数例:ADD AX, SI ; AX←(AX)+(SI),16位运算ADD X, 3 ; X←(X)+3, 运算位数由X的类型确定ADD [BX], DX ; DS:[BX]←DS:[BX]+DX, 16位运算说明:•状态标志CF, OF, ZF, SF, PF, AF按照运算结果被刷新;(2)ADC(Addition with Carry):带进位的加法指令格式:ADC dest,src功能:dest←dest+src+CFdest(目的操作数):8/16位的寄存器/存储器src(源操作数):与目的操作数同类型的寄存器/存储器/立即数说明:•状态标志CF, OF, ZF, SF, PF, AF按照运算结果被刷新;•主要用于对数据分段相加时高位的加法运算。

(3)INC(Increment):加一指令格式:INC dest功能:dest←dest+1dest(目的操作数):8/16位的寄存器/存储器例:INC X;X←(X)+1,运算位数由X的类型确定INC WORD PTR [BX];DS:[ BX] ←DS:[ BX]+1,16位运算说明:•会影响标志OF, ZF, SF, PF, AF,但是CF标志不受影响;•增量指令常常用来修改计数器和存储器指针的值。

12.减法指令(1)SUB(Subtract):减法指令格式:SUB dest,src功能:dest ← dest-srcdest(目的操作数):8/16位的寄存器/存储器src(源操作数):与目的操作数同类型的寄存器/存储器/立即数例:SUB Y, 20H ;Y←(Y)-20H,运算位数由Y的类型确定 SUB WORD PTR [BP], 5;SS:[ BP] ←SS:[ BP]-5,16位运算说明:会影响CF, OF, ZF, SF, PF, AF 标志位。

(2)SBB(Subtract with Borrow):带借位的减法指令格式:SBB dest,src功能:dest←dest-src-CFdest(目的操作数):8/16位的寄存器/存储器src(源操作数):与dest同类型的寄存器/存储器/立即数说明:•会影响CF, OF, ZF, SF, PF, AF 标志位;•主要用于对一个数据分段相减时高位的减法运算(3)DEC(Decrement):减一指令格式:DEC dest功能:dest←dest-1dest(目的操作数):8/16位的寄存器/存储器例:DEC CX ;CX←(CX) -1,16位运算DEC X ;X←(X)-1,运算位数由X的类型确定说明:•会影响标志OF, ZF, SF, PF, AF,但是CF标志不受影响;•减量指令常常用来修改计数器和存储器指针的值。

(4)NEG(Negate):求补指令(求相反数)格式:NEG dest功能:dest←0-destdest(目的操作数):8/16位的寄存器/存储器例:NEG Z ;Z←-Z,运算位数由Z的类型确定说明:会影响标志OF, ZF, SF, PF, AF, CF13.乘法指令(1)MUL(Unsigned Multiplication):无符号数乘法格式:MUL srcsrc(源操作数):8位/16位的寄存器/存储器功能:8位源操作数时:AX←(AL)×源操作数16位源操作数时:DX, AX←(AX)×源操作数说明:•两个N位操作数相乘,得到2N位的乘积;•如果乘积的高N位为0,则CF=OF=0,否则CF=OF=1。

其余标志位无意义。

•上述说明中N=8或16。

(2)IMUL(Signed Integer Multiplication):有符号数乘法格式:IMUL srcsrc(源操作数):8位/16位的寄存器/存储器功能:8位源操作数时:AX←(AL)×源操作数16位源操作数时:DX, AX←(AX)×源操作数说明:●两个N位操作数相乘,得到2N位的乘积;●如果乘积高N位为低N位的符号扩展,则CF=OF=0,否则CF=OF=1,其余标志位无意义。

●上述说明中N=8或16。

14.除法指令:DIV(Unsigned Division):无符号除法格式:DIV srcsrc(源操作数):8位/16位的寄存器/存储器功能:8位源操作数时: (AX)÷源操作数,AL←商,AH←余数16位源操作数时:(DX, AX)÷源操作数,AX←商,DX←余数说明:•两个N位操作数相除,应首先把被除数零扩展为2N位;例如,要进行除法(AX)÷(BX),假设AX、BX内均为无符号数:MOV DX, 0 ;32位被除数高16位清零DIV BX ;(DX, AX)÷BX,AX←商,DX←余数•如果(2N位)÷(N位)的商大于2N-1,会产生‚除法溢出‛错误。

•上述说明中N=8或16。

IDIV(Signed Integer Division):有符号数除法格式:IDIV srcsrc(源操作数):8位/16位的寄存器/存储器功能: 8位源操作数时:(AX)÷源操作数,AL←商,AH←余数16位源操作数时:(DX, AX) ÷源操作数,AX←商,DX←余数15.基本循环指令格式:LOOP 标号功能:CX←(CX)-1如果(CX)≠ 0,转向‚标号‛处执行,否则执行下一条指令。

说明:•LOOP可以改变指令的执行次序,称为‚控制转移指令‛;•LOOP指令使一段程序重复地执行,称为‚循环‛。

•重复执行的次数由CX寄存器中的值决定。

CX寄存器因此称为‚计数器‛。

16.DEBUG.EXE常用命令⏹反汇编‘-U ’ 、‘-U 偏移地址’⏹显示寄存器内容‘-R ’ 、‘-R 寄存器名’⏹单步执行指令‘-T ’ 、‘-T 指令条数’ 、‘-P ’⏹全速执行指令‘-G ’ 、‘-G 终止地址’、‘-G=起始地址’‘-G=起始地址终止地址’⏹显示数据段内容‘-D ’ 、‘-D 起始地址’、‘-D 起始地址L字节数’⏹修改数据段内容‘-E 起始地址数据1 数据2 …’‘-F 起始地址L字节数数据1 数据2 …’⏹退出‘-Q ’17.移位指令SHL逻辑左移,最高位进入CF,最低位补0SHR 逻辑右移,最低位进入CF,最高位补0SAL 算术左移,最高位进入CF,最低位补0SAR 算术右移,最低位进入CF,最高位不变18.循环移位指令ROL 不带进位循环左移ROR 不带进位循环右移RCL 带进位循环左移RCR 带进位循环右移18.无条件转移指令∙⑴段内转移、直接寻址∙⑵段内转移、间接寻址∙⑶段间转移、直接寻址∙⑷段间转移、间接寻址JMP label⏹转到label指定的目标地址处,执行那里的指令⏹目的地址label的位置有2种情形:⏹和JMP指令在同一个段,叫做段内转移,转移时 CPU只改变IP;⏹和JMP指令不在同一个段,叫做段间转移,转移时CPU既要更改IP又要更改CS,⏹目的地址label有两种表示方式:⏹label是目标地址处指令的标号,叫做直接寻址⏹label是寄存器或内存单元,跳转目的地址在寄存器或内存中,叫做间接寻址19.比较测试指令指令操作码指令格式功能描述CMP CMP dest, src(dest) -(src),不存结果TEST TEST dest, src(dest) ∧(src),不存结果目的操作数dest:8位/16位的寄存器/存储器操作数。

源操作数src:与dest同类型的寄存器/存储器/立即数。

功能:运算后影响标志位,但不保留运算结果。

用途:•CMP——比较两个数的大小关系,但不改变它们的值。

AX?=BX•TEST ——判断目的操作数中个别二进制位,但不改变它的值。

判断一个数的奇偶性20.条件转移指令Jxx label‚J‛----Jump‚xx‛是转移的条件‚label‛只能为目标指令的标号。

都属于段内短转移。

操作码助记符条件指令功能JZ/JE ZF=1相等或为0转移JNZ/JNE ZF=0不相等或不为0转移JS SF=1结果是负数,则转移JNS SF=0结果不是负数,则转移JO OF=1结果溢出,则转移JNO OF=0结果没有溢出,则转移JP/JPE PF=1低位字节有偶数个1,则转移JNP/JPO PF=0低位字节有奇数个1,则转移JB/JNAE/JC CF=1有进借位或<,则转移JAE/JNB/JNC CF=0无进借位或≥,则转移JBE/JNA CF=1或ZF=1≤,则转移JA/JNBE CF=0且ZF=0>,则转移JL/JNGE SF≠OF<,则转移JGE/JNL SF=OF≥,则转移JLE/JNG SF≠OF或ZF=1≤ ,则转移JG/JNLE SF=OF且ZF=0>,则转移JCXZ CX=0CX=0,则转移21.调用指令CALL(Call,调用)指令•段内直接调用格式:CALL 子程序名操作:SP← SP-2, SS:[SP] ←IP(保存16位返回地址)IP ← 子程序入口的偏移地址•段内间接调用格式:CALL REG16/MEM16操作:SP← SP-2,SS:[SP] ← IP(保护16位返回地址)IP ← REG16/MEM16•段间直接调用格式:CALL FAR PTR 子程序名操作:SP← SP-2, SS:[SP]← CSSP← SP-2, SS:[SP]← IP(以上是保存32位返回地址,偏移地址保存在较小地址处)IP ← 子程序入口的偏移地址,CS← 子程序入口的段基址•段间间接调用格式:CALL MEM32操作:SP← SP-2, SS:[SP] ← CSSP← SP-2, SS:[SP] ← IPIP← [MEM32],CS←[MEM32+2](1)CALL PROC1(2)LEA CX, PROC1CALL CX(3) ADDR_PROC1 DW PROC1 ;子程序偏移地址……CALL ADDR_PROC1 ;调用近程子程序PROC1(4)LEA BX, ADDR_PROC1CALL WORD PTR [BX] ;调用近程子程序PROC122.RET指令⏹无参数段内返回格式:RET操作:IP← SS: [SP],SP ← SP+2⏹有参数段内返回格式:RET D16 ;其中D16代表16位数据操作:IP ← SS:[SP],SP← SP+2SP ← SP+D16⏹无参数段间返回格式:RET操作:IP ← SS:[SP], SP ← SP+2CS ← SS:[SP], SP ← SP+2⏹有参数段间返回格式:RET D16 ;其中D16代表16位数据操作:IP ← SS:[SP], SP← SP+2CS ← SS:[SP], SP← SP+2SP ← SP+D1623.宏指令宏定义macro_name MACRO [哑元表] ; 形参/虚参[ LOCAL 标号表 ]…… (宏定义体)……ENDM* 如果宏定义体内有一个或多个语句标号,则必须用LOCAL伪操作列出所有的语句标号。

相关文档
最新文档