汇编指令分类介绍

合集下载

汇编语言指令详解

汇编语言指令详解

汇编语言指令详解汇编语言是一种低级语言,它直接操作计算机的硬件。

与高级语言相比,汇编语言更具操作性,可以更精确地控制计算机的执行过程。

在编写汇编语言程序时,我们需要使用指令来完成各种操作,并且对不同的指令进行详细的了解。

本文将详细介绍一些常用的汇编语言指令及其功能。

一、数据传输指令数据传输指令用于在寄存器间传输数据或将数据从寄存器传送到内存中。

常用的数据传输指令包括MOV、LDA、STA等。

MOV指令用于将数据从一个寄存器传送到另一个寄存器。

例如,MOV AX, BX表示将寄存器BX中的数据传送到寄存器AX中。

LDA指令用于将一个内存单元的数据传送到累加器中。

例如,LDA 1000H将内存单元1000H中的数据传送到累加器中。

STA指令用于将累加器的数据传送到一个内存单元中。

例如,STA 2000H将累加器中的数据传送到内存单元2000H中。

二、算术运算指令算术运算指令用于对数据进行加、减、乘、除等运算操作。

常用的算术运算指令包括ADD、SUB、MUL、DIV等。

ADD指令用于将两个操作数相加,并将结果存储在目的操作数中。

例如,ADD AX, BX表示将寄存器AX和寄存器BX的数据相加,并将结果存储在寄存器AX中。

SUB指令用于将目的操作数减去源操作数,并将结果存储在目的操作数中。

例如,SUB AX, BX表示将寄存器AX减去寄存器BX的数据,并将结果存储在寄存器AX中。

MUL指令用于执行无符号整数乘法运算。

例如,MUL AX, BX表示将寄存器AX和寄存器BX的数据相乘,并将结果存储在寄存器AX 中。

DIV指令用于执行无符号整数除法运算。

例如,DIV AX, BX表示将寄存器AX的数据除以寄存器BX的数据,并将商存储在寄存器AX 中,余数存储在寄存器DX中。

三、逻辑运算指令逻辑运算指令用于对数据进行逻辑操作,如与、或、非、位移等。

常用的逻辑运算指令包括AND、OR、NOT、SHL等。

AND指令用于对两个操作数执行位与操作,并将结果存储在目的操作数中。

汇编语言基本指令详解

汇编语言基本指令详解

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

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

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

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

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:将数据从一个位置复制到另一个位置。

•XCHG:交换两个位置的数据。

•PUSH:将数据压入栈中。

•POP:将数据从栈中弹出。

2. 算术指令算术指令用于进行算术运算。

常见的算术指令有:•ADD:将两个数相加。

•SUB:将一个数减去另一个数。

•MUL:将两个数相乘。

•DIV:将一个数除以另一个数。

3. 逻辑指令逻辑指令用于进行逻辑运算。

常见的逻辑指令有:•AND:对两个数进行逻辑与运算。

•OR:对两个数进行逻辑或运算。

•XOR:对两个数进行逻辑异或运算。

•NOT:对一个数进行逻辑非运算。

4. 控制指令控制指令用于控制程序的执行流程。

常见的控制指令有:•JMP:无条件跳转到指定的地址。

•JZ:如果上一次的运算结果为零,则跳转到指定的地址。

•JC:如果上一次的运算结果产生了进位或借位,则跳转到指定的地址。

•CALL:调用一个子程序。

三、汇编指令的应用汇编指令广泛应用于嵌入式系统、驱动程序和操作系统等领域。

下面是一些常见的应用场景:1. 嵌入式系统嵌入式系统通常具有资源有限的特点,因此需要高效地使用计算资源。

汇编语言可以直接访问硬件,提供更高的执行效率和更小的代码体积,因此在嵌入式系统中广泛使用。

2. 驱动程序驱动程序是操作系统与硬件之间的桥梁,负责将操作系统的指令翻译成硬件可以理解的指令。

由于驱动程序需要直接与硬件进行交互,因此使用汇编语言编写驱动程序可以提高执行效率和精确控制硬件。

3. 操作系统操作系统是计算机系统的核心软件,需要高效地管理计算资源和提供各种服务。

汇编语言可以直接操作硬件,提供更底层的控制和更高的执行效率,因此在操作系统的内核部分经常使用汇编语言编写。

汇编语言各种指令的解释与用法

汇编语言各种指令的解释与用法

汇编语言各种指令的解释与用法汇编语言是一种低级语言,通过编写汇编程序可以直接操作计算机硬件。

在汇编语言中,各种指令起到了关键的作用。

本文将对常用的汇编语言指令进行解释,并说明其用法。

1. 数据传输指令数据传输指令用于在存储器和寄存器之间传输数据。

常用的数据传输指令包括MOV、PUSH和POP。

- MOV指令用于将数据从一个位置传送到另一个位置。

语法格式为:MOV 目的地,源。

- PUSH指令用于将数据压入栈中。

语法格式为:PUSH 寄存器/内存地址。

- POP指令用于从栈中弹出数据并存放到指定位置。

语法格式为:POP 寄存器/内存地址。

2. 算术运算指令算术运算指令用于进行各种算术运算,如加法、减法、乘法和除法。

常用的算术运算指令有ADD、SUB、MUL和DIV。

- ADD指令实现两个操作数的加法。

语法格式为:ADD 目的操作数,源操作数。

- SUB指令实现两个操作数的减法。

语法格式为:SUB 目的操作数,源操作数。

- MUL指令实现两个操作数的乘法。

语法格式为:MUL 操作数。

- DIV指令实现两个操作数的除法。

语法格式为:DIV 操作数。

3. 分支控制指令分支控制指令用于根据条件来选择不同的执行路径,包括条件跳转和无条件跳转。

常用的分支控制指令有JMP、JZ、JE和JNE。

- JMP指令用于无条件跳转到指定的地址。

语法格式为:JMP 标号/偏移量。

- JZ指令用于在零标志位为1时跳转到指定地址。

语法格式为:JZ标号/偏移量。

- JE指令用于在相等标志位为1时跳转到指定地址。

语法格式为:JE 标号/偏移量。

- JNE指令用于在不相等标志位为1时跳转到指定地址。

语法格式为:JNE 标号/偏移量。

4. 逻辑运算指令逻辑运算指令用于实现与、或、非、异或等逻辑运算。

常用的逻辑运算指令有AND、OR、NOT和XOR。

- AND指令用于执行按位与运算。

语法格式为:AND 目的操作数,源操作数。

- OR指令用于执行按位或运算。

汇编指令与运算符

汇编指令与运算符

汇编指令与运算符1000字汇编指令和运算符是计算机系统中非常重要的组成部分,它们是编写高效计算机程序的关键。

下面将详细介绍汇编指令和运算符。

一、汇编指令1. 汇编指令的定义汇编指令是计算机系统中用于控制计算机进行不同操作的命令。

汇编指令通常由一个操作码(opcode)和一组操作数(operand)组成,可以直接映射到机器指令。

2. 汇编指令的分类根据功能不同,汇编指令可以分为以下几种类型:(1)数据传输指令数据传输指令用于在不同寄存器和存储器位置之间传输数据,例如MOV和PUSH指令。

(2)算术指令算术指令用于执行加、减、乘、除等数学运算,例如ADD、SUB、IMUL和IDIV指令。

(3)逻辑指令逻辑指令用于执行逻辑运算,例如AND、OR、XOR和NOT指令。

(4)条件转移指令条件转移指令用于根据特定条件跳转到不同的代码块,例如JZ、JNZ、JG和JL指令。

(5)无条件转移指令无条件转移指令用于跳转到程序的其他部分,例如JMP指令。

3. 汇编指令的示例以下是一些常用的x86汇编指令:(1)MOV指令:将数据从一个位置传输到另一个位置。

MOV AX, 0x1234这条指令将0x1234的值传输到AX寄存器中。

(2)ADD指令:执行加法运算。

ADD AX,BX这条指令将AX寄存器中的值与BX寄存器中的值相加,并将结果存储在AX寄存器中。

(3)CMP指令:比较两个值的大小。

CMP AX,BX这条指令将比较AX寄存器中的值与BX寄存器中的值的大小,然后将结果存储在标志寄存器中。

(4)JMP指令:无条件跳转到指定位置。

JMP 0x1234这条指令将跳转到0x1234处执行程序。

二、运算符1. 运算符的定义运算符是用于执行算术、逻辑和比较运算的符号。

在计算机编程中,运算符用于对数据进行操作和运算。

不同的编程语言支持不同的运算符。

2. 运算符的分类根据功能不同,运算符可以分为以下几种类型:(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、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不能同时为内存数、段寄存器(CS\DS\ES\SS\FS\GS)3)不能将立即数传送给段寄存器4)target 和source必须类型匹配,比如,要么都是字节,要么都是字或者都是双字等。

4)由于立即数没有明确的类型,所以将立即数传送到target时,系统会自动将立即数零扩展到与target数的位数相同,再进行传送。

有时,需要用BYTE PTR、WORD PTR、DWORD PTR明确指出立即数的位数写法示例:MOV dl,01H;MOV eax,[bp]; eax =ss:[bp]双字传送。

汇编教程汇编指令详解

汇编教程汇编指令详解

汇编教程汇编指令详解汇编语言是一种底层的计算机语言,通过使用汇编指令对计算机进行编程。

本文将对汇编指令进行详细解释,帮助读者理解和使用汇编语言。

1.数据传送指令:数据传送指令用于将数据从一个位置传送到另一个位置。

例如,MOV指令可以将数据从一个寄存器移动到另一个寄存器,或从存储器中读取数据并将其移动到寄存器中。

2.算术运算指令:算术运算指令用于执行各种算术运算,如加法、减法、乘法和除法。

例如,ADD指令可以将两个操作数相加,而MUL指令可以将两个操作数相乘。

3.逻辑运算指令:逻辑运算指令用于执行逻辑运算,如与、或、非和异或。

例如,AND指令可以对两个操作数执行按位与运算,而OR指令可以对两个操作数执行按位或运算。

4.控制转移指令:控制转移指令用于在程序执行过程中改变控制流。

例如,JMP指令可以无条件地将程序跳转到指定的地址,而条件分支指令(如JE、JNE等)可以根据特定的条件决定是否跳转。

5.程序调用指令:程序调用指令用于调用子程序。

例如,CALL指令可以将控制交给一个子程序,并在子程序执行完后返回到调用点。

6.中断指令:中断指令用于触发计算机的中断处理程序。

例如,INT 指令可以使计算机执行与指定中断向量相关联的中断处理程序。

7.输入输出指令:输入输出指令用于与计算机的外部设备进行数据交换。

例如,IN指令可以从外部设备中读取数据,而OUT指令可以向外部设备发送数据。

除了上述常用的汇编指令外,不同的计算机体系结构可能还有其他特定的指令。

因此,在学习和使用汇编语言时,了解特定体系结构的指令集是很重要的。

此外,汇编语言还包括一些程序框架和编程技巧,如标号、注释、宏定义、条件编译等。

这些工具和技巧可用于简化和优化汇编程序的开发过程。

总结起来,汇编语言是一种底层的计算机语言,通过使用各种指令对计算机进行编程。

掌握和理解各种汇编指令对于编写高效和优化的汇编程序非常重要。

希望本文能够帮助读者更好地理解和使用汇编语言。

汇编语言指令分类介绍

汇编语言指令分类介绍

8086/8088汇编语言指令集一、数据传送指令集MOV功能:把源操作数复制到目的操作数语法: MOV 目的操作数,源操作数格式:MOV ra,rbMOV r,mMOV m,rMOV r,dataXCHG功能:交换两个操作数的数据语法: XCHG 目的操作数,源操作数格式:XCHG ra,rbXCHG m,rXCHG r,mPUSH,POP功能:把操作数压入或取出堆栈语法: PUSH 操作数 POP 操作数格式:PUSH r16 ;不能使用立即数作为操作数PUSH m16POP r16POP m16PUSHF,POPF功能:保护、恢复标志寄存器格式:PUSHFPOPFLEA,LDS、LES功能:取地址至寄存器语法:LEA r16,m ;取得变量的偏移量LDS/LES r16,m ;从存储器指定单元读取连续的两个字分别存入r16及DS或ES.XLAT功能:查表指令语法: XLA T ; AL = (BX + AL)二、算数运算指令集ADD,ADC功能:加法指令语法: ADD OP1,OP2 ADC OP1,OP2格式:ADD ra,rbADD r,mADD m,rADD r,dataADD m,data影响标志:所有SUB,SBB功能:减法指令格式:SUB/SBB ra,rbSUB/SBB r,mSUB/SBB m,rSUB/SBB r,dataSUB/SBB m,data影响标志:所有INC,DEC功能:把OP的值加一或减一格式: INC/DEC r/m影响标志:P,A,Z,S,O(不影响CF!)NEG功能:对操作数求负格式: NEG r/m影响标志:所有MUL功能:乘法指令格式: MUL r/m隐含操作数:AL/AX/DX影响标志:若AH / DX 的内容为0,则CF=OF=0;否则为1。

IMUL功能:乘法指令格式:IMUL r/m隐含操作数:AL/AX/DX影响标志:若AH / DX的内容是AL / AX符号位的扩展,则:CF=OF=0;否则为1。

汇编语言常用指令大全

汇编语言常用指令大全

汇编语言常用指令大全汇编语言是一种计算机编程语言,使用指令来控制计算机硬件执行特定的操作。

在本文中,我们将介绍一些常用的汇编语言指令,以帮助读者更好地理解和学习汇编语言。

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

例子:MOV AX, BX 将寄存器BX中的值复制到寄存器AX中。

2. PUSH:将数据压入堆栈。

例子:PUSH AX 将寄存器AX中的值压入堆栈。

3. POP:从堆栈中弹出并获取数据。

例子:POP AX 从堆栈中弹出一个值,并将其存入寄存器AX中。

二、算术指令1. ADD:将两个操作数相加。

例子:ADD AX, BX 将寄存器AX和BX中的值相加,并将结果存入寄存器AX中。

2. SUB:将一个操作数从另一个操作数中减去。

例子:SUB AX, BX 将寄存器BX中的值从寄存器AX中减去,并将结果存入寄存器AX中。

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

例子:MUL AX, BX 将寄存器AX和BX中的值相乘,并将结果存入寄存器AX中。

三、逻辑指令1. AND:进行逻辑与操作。

例子:AND AX, BX 对寄存器AX和BX中的值进行逻辑与操作,并将结果存入寄存器AX中。

2. OR:进行逻辑或操作。

例子:OR AX, BX 对寄存器AX和BX中的值进行逻辑或操作,并将结果存入寄存器AX中。

3. NOT:进行逻辑非操作。

例子:NOT AX 对寄存器AX中的值进行逻辑非操作。

四、条件分支指令1. JMP:无条件跳转到指定的地址。

例子:JMP label 跳转到标记为label的地址。

2. JZ:当操作数为零时跳转到指定的地址。

例子:JZ label 如果寄存器AX中的值为零,则跳转到标记为label 的地址。

3. JC:当进位标志为1时跳转到指定的地址。

例子:JC label 如果进位标志位为1,则跳转到标记为label的地址。

五、循环指令1. LOOP:当计数器不为零时,循环执行指定的代码块。

汇编指令大全+很全的汇编指令

汇编指令大全+很全的汇编指令

for Addition)
1. 调整操作如下
格式: DAA
(1) 若(AL) and 0FH>9 或 AF=1
,则(AL)<--(AL)+6,AF<--1,对低
功能: 对AL中的两个组合进制数相加的结果进行调 四位的调整.
整,调整结果仍放在AL中,进位标志放在CF中.
(2) 若(AL) and 0F0H>90H 或
6 LAHF 标志传送指令 LAHF 格式: LAHF
2. 本指令不影响状态标位,表格 长度不超过256字节.
说明: 该指令不影响FLAG的原来 内容,AH只是复制了原FLAG的低8 位内容.
功能: 取FLAG标志寄存器低8位至AH寄存器.(AH)<-
-(FLAG)7~0
7 SAHF 标志传送指令 SAHF
说明:
格式: DEC OPRD 功能: OPRD<--OPRD-1
1. OPRD 为寄存器或存储器操作 数.
2. 这条指令执行结果影响AF、 OF、PF、SF、ZF标志位,但不影 响CF标志位.
页码,4/22
星尘-易尘
302 NEG 303 CMP
304 AAS 305 DAS 306 MUL
取补指令 NEG(NEGate)
未组合的十进制加法调整指令 AAA(ASCII Adgust 说明:
for Addition)
1. 组合的十进制数和未组合的
格式: AAA
十进制数:在计算中,十进制数可
用四位二进制数编码,称为BCD
功能: 对两个组合的十进制数相加运算(存在AL中) 码.
的结果进行调整,产生一个未组合的十进制数放在
AX中.
SUB [BX+25],AX

汇编语言重点知识总结

汇编语言重点知识总结

汇编语言重点知识总结汇编语言是一种低级程序设计语言,它直接操作计算机硬件资源,具有较高的执行效率和灵活性。

本文将重点总结汇编语言的相关知识,涵盖指令集、寻址模式、数据传送和运算、控制流等方面。

一、指令集1. 数据传送指令:包括MOV、LEA等指令,用于在寄存器和内存之间传输数据。

2. 算术运算指令:包括ADD、SUB、MUL、DIV等指令,用于进行加减乘除等数值运算。

3. 逻辑运算指令:包括AND、OR、NOT等指令,用于进行逻辑与、逻辑或、逻辑非等操作。

4. 跳转指令:包括JMP、JZ、JE等指令,用于实现程序的跳转和条件判断。

5. 栈操作指令:包括PUSH、POP等指令,用于实现数据的入栈和出栈操作。

6. 串操作指令:包括MOVSB、CMPSB等指令,用于字符串的复制、比较等操作。

二、寻址模式1. 直接寻址:使用给定的地址访问内存中的数据,如MOV AX, [1234H]。

2. 寄存器间接寻址:使用寄存器中存储的地址访问内存中的数据,如MOV BX, [SI]。

3. 寄存器相对寻址:使用寄存器和偏移量的组合访问内存中的数据,如MOV CX, [BX+DI]。

4. 基址变址寻址:使用基址寄存器和变址寄存器的组合访问内存中的数据,如MOV AX, [BX+SI+10H]。

5. 相对基址变址寻址:使用基址寄存器、变址寄存器和偏移量的组合访问内存中的数据,如MOV AX, [BX+SI+10H+DI]。

三、数据传送和运算1. 数据传送:使用MOV指令将数据从一个位置传送到另一个位置,如MOV AX, BX。

2. 位操作:使用AND、OR、XOR等指令进行位与、位或、位异或等操作。

3. 算术运算:使用ADD、SUB、MUL、DIV等指令进行加减乘除等运算。

4. 位移操作:使用SHL、SHR、ROL、ROR等指令进行位左移、位右移、循环左移、循环右移等操作。

四、控制流1. 无条件跳转:使用JMP指令无条件跳转到指定的地址。

汇编指令大全

汇编指令大全

byte cycle一、数据传送类指令MOV A, Rn 寄存器送累加器 1 1MOV Rn,A 累加器送寄存器 1 1MOV A ,@Ri 内部RAM单元送累加器 1 1MOV @Ri ,A 累加器送内部RAM单元 1 1MOV A ,#data 立即数送累加器 2 1MOV A ,direct 直接寻址单元送累加器 2 1MOV direct ,A 累加器送直接寻址单元 2 1MOV Rn,#data 立即数送寄存器 2 1MOV direct ,#data 立即数送直接寻址单元 3 2MOV @Ri ,#data 立即数送内部RAM单元 2 1MOV direct ,Rn 寄存器送直接寻址单元 2 2MOV Rn ,direct 直接寻址单元送寄存器 2 2MOV direct ,@Ri 内部RAM单元送直接寻址单元 2 2 MOV @Ri ,direct 直接寻址单元送内部RAM单元 2 2 MOV direct2,direct1 直接寻址单元送直接寻址单元 3 2 MOV DPTR ,#data16 16位立即数送数据指针 3 2MOVX A ,@Ri 外部RAM单元送累加器(8位地址) 1 2 MOVX @Ri ,A 累加器送外部RAM单元(8位地址) 1 2 MOVX A ,@DPTR 外部RAM单元送累加器(16位地址) 1 2 MOVX @DPTR ,A 累加器送外部RAM单元(16位地址) 1 2 MOVC A ,@A+DPTR 查表数据送累加器(DPTR为基址) 1 2 MOVC A ,@A+PC 查表数据送累加器(PC为基址) 1 2 XCH A ,Rn 累加器与寄存器交换 1 1XCH A ,@Ri 累加器与内部RAM单元交换 1 1XCHD A ,direct 累加器与直接寻址单元交换 2 1XCHD A ,@Ri 累加器与内部RAM单元低4位交换 1 1 SWAP A 累加器高4位与低4位交换 1 1POP direct 栈顶弹出指令直接寻址单元 2 2PUSH direct 直接寻址单元压入栈顶 2 2二、算术运算类指令ADD A, Rn 累加器加寄存器 1 1ADD A,@Ri 累加器加内部RAM单元 1 1ADD A, direct 累加器加直接寻址单元 2 1ADD A, #data 累加器加立即数 2 1ADDC A, Rn 累加器加寄存器和进位标志 1 1ADDC A,@Ri 累加器加内部RAM单元和进位标志 1 1 ADDC A, #data 累加器加立即数和进位标志 2 1ADDC A, direct 累加器加直接寻址单元和进位标志 2 1 INC A 累加器加1 1 1INC Rn 寄存器加1 1 1INC direct 直接寻址单元加1 2 1INC @Ri 内部RAM单元加1 1 1INC DPTR 数据指针加1 1 2DA A 十进制调整 1 1SUBB A, Rn 累加器减寄存器和进位标志 1 1SUBB A,@Ri 累加器减内部RAM单元和进位标志 1 1SUBB A, #data 累加器减立即数和进位标志 2 1SUBB A, direct 累加器减直接寻址单元和进位标志 2 1DEC A 累加器减1 1 1DEC Rn 寄存器减1 1 1DEC @Ri 内部RAM单元减1 1 1DEC direct 直接寻址单元减1 2 1MUL AB 累加器乘寄存器B 1 4DIV AB 累加器除以寄存器B 1 4三、逻辑运算类指令ANL A, Rn 累加器与寄存器 1 1ANL A,@Ri 累加器与内部RAM单元 1 1ANL A, direct 累加器与直接寻址单元 2 1ANL direct, A 直接寻址单元与累加器 2 1ANL direct, #data 直接寻址单元与立即数 3 1ANL A,data ;累加器A中的内容和直接地址单元中的内容执行与逻辑操作。

汇编语言指令大全

汇编语言指令大全

汇编语言指令大全前言汇编语言是一种底层的计算机语言,用于编写程序时直接操作硬件,并且能够直接控制计算机的指令执行。

在学习汇编语言时,掌握各种指令是非常重要的,本文将系统性地介绍汇编语言中常用的指令,以便读者更好地理解和使用汇编语言。

数据传送指令数据传送指令用于在寄存器、内存之间传送数据,常用的数据传送指令有MOV、XCHG等。

MOVMOV指令将数据从一个地方(来源)移动到另一个地方(目的地),语法如下:MOV 目的地, 来源例如:MOV AX, 5XCHGXCHG指令用于交换两个操作数的值,语法如下:XCHG 寄存器1, 寄存器2例如:XCHG AX, BX算术操作指令算术操作指令用于进行各种算术运算,如加法、减法、乘法、除法等,常用的算术操作指令有ADD、SUB、MUL、DIV等。

ADDADD指令用于两个操作数相加并将结果存储在目的地,语法如下:ADD 目的地, 源操作数例如:ADD AX, BXSUB指令用于从目的地减去源操作数的值,语法如下:SUB 目的地, 源操作数例如:SUB AX, 10MULMUL指令用于无符号乘法操作,将累加器AL与源操作数执行乘法,结果存储在累加器中,语法如下:MUL 源操作数例如:MUL BLDIVDIV指令用于无符号除法操作,将累加器AX中的双字数值除以源操作数,商存储在AX中,余数存储在DX中,语法如下:DIV 源操作数例如:DIV CX控制转移指令控制转移指令用于改变程序执行的顺序,如无条件跳转、条件跳转等,常用的控制转移指令有JMP、JZ、JC等。

JMPJMP指令用于无条件跳转到指定的地址执行,语法如下:JMP 目标地址例如:JMP STARTJZ指令表示“零标志”(Zero Flag),即在上一个运算结果为零时跳转到指定地址执行,语法如下:JZ 目标地址例如:JZ LOOPJCJC指令表示“进位标志”(Carry Flag),即在发生进位时跳转到指定地址执行,语法如下:JC 目标地址例如:JC ADD_OVERFLOW总结本文介绍了汇编语言中常用的数据传送指令、算术操作指令和控制转移指令,这些指令是汇编语言编程时必须掌握的基础知识。

汇编语言指令汇总

汇编语言指令汇总

汇编语言指令汇总汇编语言是一种低级编程语言,它直接操作计算机硬件,使用指令来完成特定的任务。

下面是一些常用的汇编语言指令汇总。

1.操作数传送指令:-MOV:将数据从一个位置复制到另一个位置。

-XCHG:交换两个位置中的数据。

2.算术指令:-ADD:将两个数相加并将和存储在指定位置。

-SUB:将两个数相减并将差存储在指定位置。

-MUL:将两个数相乘并将结果存储在指定位置。

-DIV:将两个数相除并将商存储在指定位置。

-INC:将一个数增加1-DEC:将一个数减少13.逻辑指令:-AND:对两个数进行逻辑与操作并将结果存储在指定位置。

-OR:对两个数进行逻辑或操作并将结果存储在指定位置。

-XOR:对两个数进行逻辑异或操作并将结果存储在指定位置。

-NOT:对一个数进行逻辑非操作并将结果存储在指定位置。

4.控制指令:-JMP:无条件跳转到指定位置。

-JZ:如果前一条指令的结果为0,则跳转到指定位置。

-JNZ:如果前一条指令的结果不为0,则跳转到指定位置。

-JC:如果前一条指令产生进位,则跳转到指定位置。

-JNC:如果前一条指令不产生进位,则跳转到指定位置。

5.栈操作指令:-PUSH:将数据放入栈中。

-POP:将栈顶的数据弹出。

6.输入输出指令:-IN:从外部设备中读取数据。

-OUT:将数据发送到外部设备。

7.循环指令:-LOOP:根据计数寄存器的值,重复执行指定的代码块。

8.过程调用指令:-CALL:调用一个子程序。

-RET:从子程序返回。

9.字符串指令:-MOVS:将一个字节或一个字从一个位置复制到另一个位置。

-CMPS:将两个位置中的字节或字进行比较。

除了以上提到的指令外,不同的汇编语言还有其它特定的指令,用于特定的硬件操作或功能实现。

这些指令的语法与使用方法可能略有不同,具体请参考所使用的汇编语言的文档或手册。

总之,汇编语言指令是汇编语言的基础,熟练掌握和理解这些指令对于编写高效和可靠的汇编程序至关重要。

汇编指令分类及使用方法

汇编指令分类及使用方法

汇编指令分类及使用方法汇编指令可以分为以下几类:数据传输指令、算术运算指令、逻辑运算指令、转移指令和其他指令等。

一、数据传输指令1. MOV(Move)指令:用于将数据从源操作数传输到目的操作数。

例如:MOV AX, BX 将BX寄存器中的数据传输到AX寄存器中。

2. PUSH(Push)指令:将数据压栈。

例如:PUSH AX 将AX寄存器中的数据压入栈中。

3. POP(Pop)指令:将数据从栈弹出。

例如:POP AX 将栈顶数据弹出然后存入AX寄存器中。

二、算术运算指令1. ADD(Addition)指令:将两个操作数相加。

例如:ADD AX, BX 将AX和BX寄存器中的数据相加并存储在AX寄存器中。

2. SUB(Subtraction)指令:将第二个操作数从第一个操作数中减去。

例如:SUB AX, BX 将AX寄存器中的数据减去BX寄存器中的数据并存储在AX寄存器中。

3. MUL(Multiply)指令:将两个操作数相乘,结果存储在一个乘法寄存器中。

例如:MUL AX, BX 将AX寄存器中的数据与BX寄存器中的数据相乘并存储在AX:DX寄存器对中。

三、逻辑运算指令1. AND(And)指令:对两个操作数逐位执行逻辑与运算。

例如:AND AX, BX 将AX和BX寄存器中的数据逐位执行逻辑与运算并存储在AX寄存器中。

2.OR(Or)指令:对两个操作数逐位执行逻辑或运算。

例如:ORAX,BX将AX和BX寄存器中的数据逐位执行逻辑或运算并存储在AX寄存器中。

3. XOR(Exclusive Or)指令:对两个操作数逐位执行逻辑异或运算。

例如:XOR AX, BX 将AX和BX寄存器中的数据逐位执行逻辑异或运算并存储在AX寄存器中。

四、转移指令1.JMP(JuMP)指令:无条件跳转到一些标号或地址。

例如:JMPLABEL1将程序转移到LABEL1处。

2. JE(Jump Equal)指令:当两个操作数相等时跳转。

汇编语言指令

汇编语言指令

汇编语言指令汇编语言是一种低级语言,用于编写计算机程序。

在汇编语言中,指令起着至关重要的作用,它们直接控制着计算机的运行。

本文将介绍几种常见的汇编语言指令。

1. 数据传送指令数据传送指令用于将数据从一个地方传送到另一个地方。

常见的数据传送指令包括MOV(move)指令和LEA(load effective address)指令。

MOV指令可以将数据从一个寄存器或内存位置传送到另一个寄存器或内存位置。

LEA指令将源操作数的有效地址加载到目标寄存器中。

2. 算术运算指令算术运算指令用于进行各种数学运算,包括加法、减法、乘法和除法等。

常用的算术运算指令有ADD(addition)指令和SUB (subtraction)指令。

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

SUB指令可以实现减法运算。

3. 逻辑运算指令逻辑运算指令用于执行逻辑运算,如与、或、非等。

与运算用AND指令表示,或运算用OR指令表示,非运算用NOT指令表示。

这些指令可以对某一位或多位进行逻辑运算,并将结果存储到目标操作数中。

4. 控制转移指令控制转移指令用于改变程序的执行顺序。

常见的控制转移指令包括JMP(jump)、JZ(jump if zero)和JC(jump if carry)等。

JMP指令用于无条件跳转到指定的目标地址。

JZ指令在零标志位为真时跳转,用于实现条件语句。

JC指令在进位标志位为真时跳转,常用于实现循环。

5. 栈操作指令栈操作指令用于对堆栈进行操作。

堆栈是一种后进先出(LIFO)的数据结构,常用于保存和恢复程序的上下文。

常见的栈操作指令有PUSH(push)和POP(pop)。

PUSH指令将一个数据压入堆栈,而POP指令将栈顶数据弹出。

6. 输入输出指令输入输出指令用于与外部设备进行数据的输入和输出。

常见的输入输出指令包括IN(input)和OUT(output)。

IN指令用于从指定的端口读取数据,而OUT指令用于将数据输出到指定的端口。

汇编语言指令大全

汇编语言指令大全

汇编语言指令大全汇编语言是一种低级语言,它直接使用计算机的指令集架构,能够直接控制计算机硬件。

在学习和使用汇编语言时,了解各种指令是非常重要的。

本文将为您介绍汇编语言中常用的指令,帮助您更好地理解和应用汇编语言。

一、数据传送指令。

数据传送指令用于将数据从一个位置传送到另一个位置,常用的数据传送指令包括MOV、XCHG等。

MOV指令用于将数据从一个位置复制到另一个位置,而XCHG指令则用于交换两个位置的数据。

二、算术运算指令。

算术运算指令用于对数据进行算术运算,包括加法、减法、乘法、除法等。

常用的算术运算指令有ADD、SUB、MUL、DIV等。

这些指令可以帮助程序实现各种复杂的算术运算。

三、逻辑运算指令。

逻辑运算指令用于对数据进行逻辑运算,包括与、或、非、异或等。

常用的逻辑运算指令有AND、OR、NOT、XOR等。

这些指令可以帮助程序实现各种逻辑运算,如逻辑与、逻辑或、逻辑非等。

四、条件转移指令。

条件转移指令用于根据条件来改变程序的执行顺序,包括跳转、循环等。

常用的条件转移指令有JMP、JE、JNE、JG、JL等。

这些指令可以帮助程序实现各种条件判断和跳转。

五、程序控制指令。

程序控制指令用于控制程序的执行流程,包括调用子程序、返回、中断等。

常用的程序控制指令有CALL、RET、INT等。

这些指令可以帮助程序实现模块化编程和中断处理。

六、字符串操作指令。

字符串操作指令用于对字符串进行操作,包括复制、比较、连接等。

常用的字符串操作指令有MOVS、CMPS、LODS、STOS等。

这些指令可以帮助程序实现对字符串的高效处理。

七、输入输出指令。

输入输出指令用于与外部设备进行数据交换,包括从外部设备输入数据、向外部设备输出数据等。

常用的输入输出指令有IN、OUT等。

这些指令可以帮助程序实现与外部设备的通信。

总结。

汇编语言指令种类繁多,每种指令都有其特定的功能和用途。

掌握这些指令,能够帮助程序员更好地编写高效、精确的汇编语言程序。

汇编指令分类

汇编指令分类

汇编指令分类汇编汇编语⾔包含两种指令:1. 汇编指令2. 伪指令伪指令没有对应的机器指令,最终不会被CPU执⾏。

伪指令是编译器执⾏的指令。

segement和endssegement 表⽰⼀个段的开始,ends表⽰⼀个段的结束段名 segment段名 ends⽐如:codesg segementcodesg ends;end表⽰⼀个汇编程序的结束标记,编译器在编译的时候如果碰到了end,就会结束对源程序的编译assume假设某⼀段寄存器和程序中的某⼀个⽤segment...ends定义的段相关联。

标号⼀个标号指代了⼀个地址,步过循环p遇到loop使⽤p来进⾏跳过跳到指定的语句g ip使⽤g ip跳到指定语句start 告诉程序的⼊⼝assume cs:codecode segmentdw 0123h, 0456h, 0789h, 0abch, 0defh, 0fedh, 0cbah, 0987hstart: mov bx, 0 ; 跳过前⾯的数据,不加start代码会从数据处开始mov ax, 0mov cx, 8s:add ax, cs:[bx]add bx, 2loop smov ax, 4c00hint 21hcode endsend start汇编指令汇编只有是有对应的机器码的指令,可以被便以为机器指令,最终为CPU所执⾏。

loopassume cs:codecode segmentmov ax,2mov cx,11s: add ax,axloop smov ax, 4c00Hint 21Hcode endsendloop 执⾏之后,寄存器cx会⾃动减⼀,直到减到0,跳出循环执⾏loop的下⼀条语句段前缀 ds, cs, ss, es指令mov ax, [bx]中,内存的那元的偏移地址由bx给出,⽽段地址默认在ds中。

我们可以在访问内存单元的指令中显式地给出内存单元的段地址所在的段寄存器。

汇编指令

汇编指令

汇编指令汇编指令是汇编语言中使用的一些操作符(如mov,inc,loop)和助记符,还包括一些伪指令(如assume,end).用于告诉汇编程序如何进行汇编的指令,它既不控制机器的操作也不被汇编成机器代码,只能为汇编程序所识别并指导汇编如何进行。

汇编指令大全一、数据传输指令───────────────────────────────────────它们在存贮器和寄存器、寄存器和输入输出端口之间传送数据.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.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 标志出栈.PUSHD 32位标志入栈.POPD 32位标志出栈.二、算术运算指令───────────────────────────────────────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时,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 清中断允许位.六、伪指令───────────────────────────────────────DW 定义字(2字节).PROC 定义过程.ENDP 过程结束.SEGMENT 定义段.ASSUME 建立段寄存器寻址.ENDS 段结束.END 程序结束.七、处理机控制指令:标志处理指令CLC(进位位置0指令)CMC(进位位求反指令)STC(进位位置为1指令)CLD(方向标志置1指令)STD(方向标志位置1指令)CLI(中断标志置0指令)STI(中断标志置1指令)NOP(无操作)HLT(停机)WAIT(等待)ESC(换码)LOCK(封锁)。

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

汇编指令全集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、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不能同时为内存数、段寄存器(CS\DS\ES\SS\FS\GS)3)不能将立即数传送给段寄存器4)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)类型必须匹配3)两个操作数任何一个都不能是段寄存器【看来段寄存器的写入的限制非常的严格,MOV指令也不能对段寄存器进行写入】,4)必须是通用寄存器(ax、bx、cx、dx、si、di)或内存数写法示例:XCHG ax,[bx][si]; XCHG ax,bx;3、LEA(装入有效地址)指令写法:LEZ reg16,mem功能描述:将有效地址MEM的值装入到16位的通用寄存器中。

写法示例:假定bx=5678H,EAX=1,EDX=2Lea si,2[bx];si=567AHLea di,2[eax][edx];di=5注意,这里装入的是有效地址,并不是实际的内存中的数值,如果要想取内存中该地址对应的数值,还需要加上段地址才行,而段地址有可能保存在DS中,也有可能保存在SS或者CS中哦:>不知道我的理解可正确。

4、LDS\LES\LGS\LSS(注意,与LEA不同的是,这里是装入的值,而不是有效地址)这几个指令,名称不同,作用差不多。

写法:LDS reg16,mem32功能描述:reg16等于mem32的低字,而DS对应于mem32的高字(当为LES时,这里就是ES对应于mem32的高字)用来给一个段寄存器和一个16位通用寄存器同时复制。

注意事项:第一个操作数必须是16位通用寄存器在接着往下说之前,先熟悉下堆栈的概念。

堆栈,位于内存的堆栈段中,是内存的一部分,具有“先进后出”的特点,堆栈只有一个入口,即当前栈顶,当堆栈为空时,栈顶和栈底指向同一内存地址,在WINDOWS中,可以把堆栈理解成一个倒着的啤酒瓶,上面的地址大,下面的地址小,当从瓶口往啤酒瓶塞啤酒时(进栈),栈顶就会往瓶口下移动,也就是往低地址方向移动,同理,出栈时,正好相反,把啤酒给倒出来,栈顶向高地址方向移动。

这就是所谓的堆栈,哼哼,很Easy吧。

在汇编语言中,堆栈操作的最小单位是字,也就是说,只能以字或双字为单位,同时,SS:SP指向栈顶(SS为堆栈段寄存器,SP为堆栈指针,二者一相加,就构成了堆栈栈顶的内存地址)。

5、PUSH(进栈)写法:PUSH 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、POPAD作用:将所有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通常可以用来交换两个寄存器的值,也可以用来保护寄存器的值,如下:交换ax与cx的值:push ax;push cx;pop ax;pop cx;保护寄存器:push ax;push cx;….中间有很多执行的代码…pop cx;pop ax;9、LAHF\SAHF(标志寄存器传送指令)写法:lahf;作用:AH=FLAGS的低8位写法:sahf;作用:FLAGS的低8位=AH10、符号扩展和零扩展指令CBW;AL符号扩展为AXCWD;AX符号扩展为32位数DX:AXCWDE;AX符号扩展为EAX;CDQ:EAX符号扩展为64位数EDX:EAXMOVSX(符号扩展指令的一般形式)写法:MOVSX reg16\32,reg8\reg16\mem8\mem16作用:用来将8位符号扩展到16位,或者16位符号扩展到32位MOVZX(零扩展指令)写法:MOVZX reg16\32,reg8\reg16\mem8\mem16零扩展,就是高位补0进行扩展。

通常用在将数据复制到一个不同的寄存器中,如AL零扩展为EBX。

相同寄存器的零扩展,可以使用MOV 高位, 0来实现。

11、BSWAP(字节交换)写法:bswap reg32作用:将reg32的第0与第3个字节,第1与第2个字节进行交换。

示例:设EAX=12345678h执行bswap eax;后,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作用:将后面的操作数加到前面的操作数中注意:两个操作数必须类型匹配,并且不能同时是内存操作数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;作用:dest=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(比较交换)写法: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到mem64指定的内存地址;否则,置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/mem32/imm32;注意:没有两个操作数均为8位的多操作数乘法。

相关文档
最新文档