汇编语言重点知识总结
汇编语言基础知识

例 0. 1
01
0
01
+
+
+
+
+
÷2
÷2 ÷2
÷2
÷2
÷2
0.640625 0.28125 0.5625 0.125 0.25 0.5
0.101001B=0.640625D
24
5. 二进制与八进制和十六进制间的转换
二进制与八进制和十六进制之间的对应关系很简单: 三位二进制数对应一位八进制数,四位二进制数对 应一位十六进制数。
第一章 基础知识
本章主要学习内容: 1.汇编语言的一般概念 2.学习和使用汇编语言的目的 3.进位计数制及其相互转换 4.带符号数的表示 5.字符的表示 6.基本逻辑运算
4
§1.1 汇编语言的一般概念
计算机程序设计语言可分为机器语言、高级 语言和汇编语言三类。
1. 机器语言 机器语言就是把控制计算机的命令和各种数83. Nhomakorabea汇编语言
(1)定义 虽然高级语言方便了人对计算机的使用,但
其运行效率较低。在一些应用场合,如系统管 理,实时控制等,难于满足要求。因此又希望使 用机器语言。
为了便于记忆和阅读,使用字母和符号来 表示机器语言的命令,用十进制数或十六进制 数来表示数据,这样的计算机程序设计语言就 称为汇编语言。
18
例:将325转换为二进制数,直到余数为0。 首先确定二进制数的最高位 因为29(512)>325>28(256)。因此从K8位开始比较。
减数比较
Ki
325-256=69
K8
69<128
K7
69-64=5
K6
5<32
K5
5<16
汇编语言基础知识

汇编语言基础知识汇编语言是直接在硬件之上工作的编程语言,首先要了解硬件系统的结构,才能有效地应用汇编语言对其编程,因此,本章对硬件系统结构的问题进行部分探讨,首先介绍了计算机的基本结构、Intel 公司微处理器的发展、计算机的语言以及汇编语言的特点,在此基础上重点介绍寄存器、内存组织等汇编语言所涉及到的基本知识。
1.1 微型计算机概述微型计算机由中央处理器(Central Processing Unit ,CPU )、存储器、输入输出接口电路和总线构成。
CPU 如同微型计算机的心脏,它的性能决定了整个微型计算机的各项关键指标。
存储器包括随机存储器(Random Access Memory ,RAM )和只读存储器(Read Only Memory ,ROM )。
输入输出接口电路用来连接外部设备和微型计算机。
总线为CPU 和其他部件之间提供数据、地址和控制信息的传输通道。
如图1.1所示为微型计算机的基本结构。
外部设备存储器输入输出接口电路中央处理器CPU地址总线数据总线控制总线图1.1 微型计算机基本结构特别要提到的是微型计算机的总线结构,它使系统中各功能部件之间的相互关系变为各个部件面向总线的单一关系。
一个部件只要符合总线结构标准,就可以连接到采用这种总线结构的系统中,使系统功能得到扩展。
数据总线用来在CPU 与内存或其他部件之间进行数据传送。
它是双向的,数据总线的位宽决定了CPU 和外界的数据传送速度,8位数据总线一次可传送一个8位二进制数据(即一个字节),16位数据总线一次可传送两个字节。
在微型计算机中,数据的含义是广义的,数据总线上传送的不一定是真正的数据,而可能是指令代码、状态量或控制量。
地址总线专门用来传送地址信息,它是单向的,地址总线的位数决定了CPU 可以直接寻址的内存范围。
如CPU 的地址总线的宽度为N ,则CPU 最多可以寻找2N 个内存单元。
控制总线用来传输控制信号,其中包括CPU送往存储器和输入输出接口电路的控制信号,如读信号、写信号和中断响应信号等;也包括其他部件送到CPU的信号,如时钟信号、中断请求信号和准备就绪信号等。
汇编语言知识大全

汇编语言知识大全汇编语言是计算机科学领域的重要组成部分,它是一种低级语言,用于在计算机硬件上进行编程。
了解和掌握汇编语言对于想要深入了解计算机体系结构和进行底层编程的人来说是非常重要的。
本文将为您提供一份汇编语言知识大全,涵盖汇编语言的基础知识、指令集、程序开发和调试技巧等方面。
一、汇编语言的基础知识1. 什么是汇编语言?汇编语言是一种机器语言的符号表示方法,通过使用助记符(mnemonic)代表特定的二进制指令,使得程序员可以更容易地编写和理解机器代码。
2. 汇编语言和高级语言的区别是什么?汇编语言主要是面向机器的,使用指令来直接控制硬件的操作,而高级语言更加抽象,使用更接近自然语言的语法结构,通过编译器或解释器将其翻译为机器码。
3. 为什么需要学习汇编语言?学习汇编语言可以让我们更好地理解计算机的底层工作原理,能够更加高效地编写程序,优化性能,并且在某些特定的应用中,汇编语言可以实现一些高级语言所不能达到的功能。
二、汇编语言的指令集1. 汇编语言的指令格式汇编语言的指令一般包含操作码(Opcode)、操作数(Operand)和注释三个部分,其中操作码表示要执行的操作,操作数表示要操作的数据,而注释则是对指令的解释说明。
2. 汇编语言的常用指令在汇编语言中,常用指令包括数据传输指令、算术和逻辑指令、控制指令等等。
比如MOV指令用于数据传输,ADD指令用于加法操作,JMP指令用于无条件跳转等。
3. 汇编语言的寻址方式寻址方式是指汇编语言中用于定位操作数的方法,常见的寻址方式有直接寻址、间接寻址、寄存器寻址等。
不同的寻址方式适用于不同的操作场景。
三、汇编语言的程序开发1. 程序结构汇编语言的程序通常由代码段、数据段和堆栈段组成。
代码段用于存放程序的指令,数据段用于存放程序的数据,而堆栈段则用于存放程序的运行时信息。
2. 程序调用在汇编语言中,程序之间的调用可以通过CALL和RET指令来实现。
CALL用于调用子程序,将当前代码的执行流程转移到被调用的子程序中,而RET则用于返回调用点。
第1章汇编语言知识学习基本知识

第1章汇编语⾔知识学习基本知识第1章汇编语⾔基础知识本章介绍学习汇编语⾔程序设计所必须具备的基本知识,主要包括汇编语⾔的基本概念及计算机中数据的表⽰⽅法。
通过本章的学习,读者应能了解汇编语⾔概念及其使⽤的进位计数制、不同进位计数制之间的转换、计算机编码以及基本数据类型。
本章内容要点:汇编语⾔的概念汇编语⾔的特点不同进位计数制之间的转换计算机编码1.1汇编语⾔概述1.1.1 汇编语⾔基本概念⾃然语⾔是具有特定语⾳和语法等规范的、⽤于⼈类表达思想并实现相互交流的⼯具。
⼈与⼈之间只有使⽤同⼀种语⾔才能进⾏直接交流,否则就必须通过翻译。
要使计算机为⼈类服务,⼈们就必须借助某种⼯具,告诉计算机“做什么”甚⾄“怎么做”,这种⼯具就是程序设计语⾔。
程序设计语⾔通常分为三类:机器语⾔、汇编语⾔和⾼级语⾔。
⽽前两种语⾔与机器密切相关,统称为低级语⾔。
1.机器语⾔机器语⾔是计算机第⼀代语⾔,它全部由0、1代码组成,是能够直接被机器所接受的语⾔,是最底层的计算机语⾔。
机器语⾔不容易记忆,程序编写难度⼤,调试修改繁琐,且不易移植,现在程序员很少⽤。
但机器语⾔执⾏速度最快,它是⼀种⾯向机器的程序设计语⾔。
2.汇编语⾔为了克服机器语⾔难以记忆、表达和阅读的缺点,⼈们采⽤具有⼀定含义的符号作为助忆符,⽤指令助忆符、符号地址等组成的符号指令称为汇编格式指令(或汇编指令)。
例如,⽤ADD表⽰加法指令,SUB表⽰减法指令,MOV表⽰传送指令等。
汇编语⾔是汇编指令集、伪指令集和使⽤它们规则的统称。
伪指令的概念将在第4章介绍。
汇编语⾔⽐机器语⾔直观,容易记忆和理解,⽤汇编语⾔编写的程序也⽐机器语⾔程序易读、易检查、易修改。
对于不同的计算机,针对同⼀问题所编写的汇编语⾔源程序是互不通⽤的。
⽤汇编语⾔编写的程序执⾏效率⽐较⾼,但通⽤性与可移植性仍然⽐较差。
计算机不能直接识别⽤汇编语⾔编写的程序,必须由⼀种专门翻译程序将汇编语⾔程序翻译成机器语⾔程序,计算机才能执⾏。
risc-v 汇编语言编程

risc-v 汇编语言编程RISC-V是一种基于精简指令集(RISC)的开源指令集架构,它的指令集简单、规范、可扩展,因此在学术界和工业界都备受关注。
本文将介绍RISC-V汇编语言编程的基础知识和一些常用的指令。
一、RISC-V汇编语言基础知识RISC-V汇编语言是一种基于指令集架构的汇编语言,它的语法规范简单易懂。
下面是一些基础知识:1. 寄存器RISC-V有32个通用寄存器,分别用x0~x31表示。
其中x0始终为零寄存器,不能被写入。
x1通常用作返回值寄存器,x2~x11用作临时寄存器,x12~x17用作参数寄存器,x18~x27用作临时寄存器,x28~x31用作保留寄存器。
2. 指令格式RISC-V指令格式分为三种:R型、I型和S型。
R型指令用于寄存器之间的操作,I型指令用于立即数和寄存器之间的操作,S型指令用于存储操作。
3. 标签标签是汇编语言中用于标识代码位置的符号,以“.”开头。
标签通常用于跳转指令的目标地址。
二、常用指令下面介绍一些常用的RISC-V指令:1. 加法指令add x1, x2, x3该指令将x2和x3寄存器中的值相加,结果存储到x1寄存器中。
2. 减法指令sub x1, x2, x3该指令将x2和x3寄存器中的值相减,结果存储到x1寄存器中。
3. 加载指令lw x1, 0(x2)该指令将x2寄存器中的地址加上0,得到的地址处的值存储到x1寄存器中。
4. 存储指令sw x1, 0(x2)该指令将x1寄存器中的值存储到x2寄存器中的地址加上0的位置。
5. 分支指令beq x1, x2, label该指令比较x1和x2寄存器中的值是否相等,如果相等则跳转到label标签处。
6. 跳转指令j label该指令无条件跳转到label标签处。
7. 系统调用指令ecall该指令用于进行系统调用,例如输出字符串。
三、总结本文介绍了RISC-V汇编语言编程的基础知识和常用指令。
RISC-V指令集架构的简单、规范、可扩展使得它在学术界和工业界都备受关注。
汇编语法大全

汇编语法大全汇编语言是一种底层的计算机语言,可以用来编写应用程序、驱动程序和嵌入式系统等。
其语法简洁、效率高,但也较为复杂。
下面是汇编语法大全,希望对大家能有所帮助。
1. 注释语句注释语句是程序员为了方便自己和他人阅读代码而添加的语句。
汇编语言中,使用分号(;)表示注释语句,写在行尾。
示例:mov ax, bx ;将bx寄存器的值赋给ax寄存器2. 标号语句标号语句用来表示程序中的一个位置,在汇编程序中可以用它来实现跳转、条件执行等功能。
标号语句必须在第一行,以字母开头,由数字、字母和下划线组成,长度不超过32个字符。
3. 数据定义语句数据定义语句用来为变量、常量分配存储空间,可以为它们指定初值。
汇编语言中,数据定义语句有三种形式:db、dw、dd。
db:定义一个字节(8位)长度的数据,可以用来存储字符、布尔型变量等。
data1 db 'A' ;定义一个字符型变量,初值为'A'4. 操作数表示操作数即指令中被操作的对象,可以是通用寄存器、内存单元、立即数等。
汇编指令中,操作数的表示方法主要有以下几种:寄存器表示法:使用寄存器的名称表示操作数,如AL、AX、DX等。
立即数表示法:表示一个常量数值,用于参与运算或存储到内存中,如100、0AH等。
内存变量表示法:使用内存变量的地址表示操作数,如[2000H]、[BX]等。
mov al, 02h ;将立即数02h赋给AL寄存器mov byte ptr ds:[bx], al ;将AL寄存器的值存储到2000h地址所指向的内存单元中5. 寻址方式汇编语言中,寻址方式用于表示操作数在内存中的地址。
汇编语言提供了多种寻址方式,例如寄存器间接寻址、基址变址寻址、相对寻址等。
寄存器间接寻址寄存器间接寻址是指操作数的地址存储在一个寄存器中。
例如,[BX]表示将BX寄存器中的值作为地址,访问该地址存储的数据。
基址变址寻址相对寻址相对寻址是指让程序计算出偏移量以便于寻址,这种寻址方式用于程序中的跳转指令。
汇编语言的基本语法

汇编语言的基本语法在计算机科学领域中,汇编语言是一种低级语言,用于编写计算机程序。
它直接操作计算机硬件,比高级语言更接近计算机底层。
汇编语言的使用需要对其基本语法有一定的了解。
本文将介绍汇编语言的基本语法,以帮助读者更好地理解和使用这种语言。
一、数据传送指令在汇编语言中,数据传送是最基本的操作之一。
它用于将一个数据从一个位置传送到另一个位置。
数据传送指令由源操作数和目的操作数组成,示例如下:MOV 目的操作数,源操作数其中,目的操作数是要传送数据的目标位置,源操作数是数据的来源位置。
例如,将一个常量值传送给寄存器AX的指令可以写成:MOV AX,1000H这条指令将十六进制常量1000H传送给寄存器AX。
二、算术指令在汇编语言中,算术指令用于对数据进行算术运算。
常见的算术运算包括加法、减法、乘法和除法。
以下是一些常用的算术指令示例:ADD 目的操作数,源操作数 ; 相加SUB 目的操作数,源操作数 ; 相减MUL 目的操作数,源操作数 ; 乘法DIV 目的操作数,源操作数 ; 除法其中,目的操作数是要进行运算的操作数存储位置,源操作数是用于运算的数据来源。
三、跳转指令在程序执行过程中,跳转指令用于改变程序的执行顺序。
它根据条件选择不同的路径执行,或者直接跳转到指定的地址。
常见的跳转指令有以下几种形式:JMP 目标地址 ; 无条件跳转JE 目标地址 ; 相等时跳转JNE 目标地址 ; 不相等时跳转JG 目标地址 ; 大于时跳转JGE 目标地址 ; 大于等于时跳转JL 目标地址 ; 小于时跳转JLE 目标地址 ; 小于等于时跳转这些指令根据前面的条件判断进行跳转。
四、循环指令在汇编语言中,循环指令用于重复执行一段程序。
常见的循环指令有以下两种形式:LOOP 目标地址 ; 循环指令,计数器减1并跳转JCXZ 目标地址 ; 循环指令,计数器为0时跳转这些指令根据指定的条件进行重复执行,直到条件不满足为止。
汇编语言关键字

汇编语言关键字在计算机科学领域中,汇编语言是一种低级别的编程语言,用于与计算机硬件进行直接交互。
它是计算机指令的文本表示,由一系列的关键字组成。
了解和熟悉汇编语言的关键字对于理解计算机底层运行机制以及进行系统级编程至关重要。
本文将介绍一些常见的汇编语言关键字,帮助读者了解其功能和用法。
一、数据传输指令数据传输指令用于将数据从一个位置传输到另一个位置。
以下是几个常见的数据传输指令:1. MOV:MOV指令用于将一个数据从一个位置复制到另一个位置。
它可以用于将数据从寄存器传输到内存,或者从内存传输到寄存器。
2. PUSH:用于将数据压入堆栈中。
堆栈是一种后进先出(LIFO)的数据结构,常用于存储临时变量和函数调用返回地址。
3. POP:与PUSH相反,POP指令用于将数据从堆栈中弹出,并存储到指定的位置。
二、算术和逻辑指令算术和逻辑指令用于对数据进行算术和逻辑运算。
以下是一些常用的算术和逻辑指令:1. ADD:用于将两个数相加,并将结果保存在指定位置。
可以用于寄存器之间的相加,也可以用于寄存器和内存之间的相加。
2. SUB:与ADD类似,SUB指令用于将一个数减去另一个数,并将结果保存在指定位置。
3. AND:用于执行按位与运算。
将两个数的每个对应位作与操作,并将结果保存在指定位置。
4. OR:与AND指令类似,OR指令用于执行按位或运算。
5. XOR:用于执行按位异或运算。
将两个数的每个对应位作异或操作,并将结果保存在指定位置。
三、分支和循环指令分支和循环指令用于控制程序的流程和执行顺序。
以下是一些常用的分支和循环指令:1. JMP:JMP指令用于无条件跳转到指定的地址。
可以用于实现程序的跳转和循环。
2. JZ和JNZ:JZ指令用于在前一个操作的结果为零时跳转到指定地址,而JNZ则相反,用于在结果不为零时跳转。
3. CMP:CMP指令用于比较两个数据的大小关系,并根据比较结果设置标志位,用于后续的条件跳转。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
汇编语言重点知识总结汇编速查手册汇编语言总结概要寄存器与存储器1.寄存器功能.寄存器的一般用途和专用用途.CS:IP控制程序执行流程.SS:SP提供堆栈栈顶单元地址.DS:BX(SI,DI)提供数据段内单元地址.SS:BP提供堆栈内单元地址.ES:BX(SI,DI)提供附加段内单元地址.AX,CX,BX和CX寄存器多用于运算和暂存中间计算结果,但又专用于某些指令(查阅指令表)。
.PSW程序状态字寄存器只能通过专用指令(LAHF,SAHF)和堆栈(PUSHF,POPF)进行存取。
2.存储器分段管理.解决了16位寄存器构成20位地址的问题.便于程序重定位.20位物理地址=段地址*16+偏移地址.程序分段组织:一般由代码段,堆栈段,数据段和附加段组成,不设置堆栈段时则使用系统内部的堆栈。
3.堆栈.堆栈是一种先进后出的数据结构,数据的存取在栈顶进行,数据入栈使堆栈向地址减小的方向扩展。
.堆栈常用于保存子程序调用和中断响应时的断点以及暂存数据或中间计算结果。
.堆栈总是以字为单位存取指令系统与寻址方式1.指令系统.计算机提供给用户使用的机器指令集称为指令系统,大多数指令为双操作数指令。
执行指令后,一般源操作数不变,目的操作数被计算结果替代。
.机器指令由CPU执行,完成某种运算或操作,8086/8088指令系统中的指令分为6类:数据传送,算术运算,逻辑运算,串操作,控制转移和处理机控制。
2.寻址方式.寻址方式确定执行指令时获得操作数地址的方法.分为与数据有关的寻址方式(7种)和与转移地址有关的寻址方式(4)种。
.与数据有关的寻址方式的一般用途:(1)立即数寻址方式--将常量赋给寄存器或存储单元(2)直接寻址方式--存取单个变量(3)寄存器寻址方式--访问寄存器的速度快于访问存储单元的速度(4)寄存器间接寻址方式--访问数组元素(5)变址寻址方式(6)基址变址寻址方式(7)相对基址变址寻址方式(5),(6),(7)都便于处理数组元素.与数据有关的寻址方式中,提供地址的寄存器只能是BX,SI,DI或BP.与转移地址有关的寻址方式的一般用途:(1)段内直接寻址--段内直接转移或子程序调用(2)段内间接寻址--段内间接转移或子程序调用(3)段间直接寻址--段间直接转移或子程序调用(4)段间间接寻址--段间间接转移或子程序调用汇编程序和汇编语言1.汇编程序.汇编程序是将汇编语言源程序翻译成二进制代码程序的语言处理程序,翻译的过程称为汇编。
2.汇编语言.汇编语言是用指令助记符,各种标识变量,地址,过程等的标识符书写程序的语言,汇编语言指令与机器指令一一对应。
.伪指令,宏指令不是由CPU执行的指令,而是由汇编程序在汇编期间处理的指令。
.伪指令指示汇编程序如何完成数据定义,存储空间分配,组织段等工作。
.宏指令可简化程序并减少程序书写量。
.条件汇编伪指令的功能是确定是否汇编某段源程序,而不是实现程序分支,对未汇编的程序将不产生相应的目标代码。
.结构作为一种数据结构可将一组类型不同但有逻辑关联的数据组织在一起,便于整体处理数据。
.记录可用于提高存储单元的利用率,将若干不足一个字节或字且有逻辑关联的信息压缩存放在一个字节或字中。
.指令中的表达式在汇编期间计算,并且只能对常量或地址进行计算。
程序设计基础1.分支程序设计.程序分支由条件转移指令或无条件转移指令实现.存放若干目的转移地址或跳转指令的跳转表常用于实现多路分支.条件转移指令只能实现偏移量为-128至+127字节范围的转移.无条件转移指令根据寻址方式可实现短转移(偏移量为-128至+127字节),段内转移,段间转移。
2.循环程序设计.可由循环控制指令或条件转移指令组织循环结构.内层循环结构必须完全包含在外层循环结构内,并不能发生从循环结构外向循环结构内的转移。
3.子程序设计.子程序中应保护寄存器内容,并正确使用堆栈,成对执行PUSH和POP指令,保证执行RET 指令时堆栈栈顶为返回地址。
.主程序可通过寄存器,参数表,或堆栈传递参数给子程序4.EXE文件和COM文件.二者都是可执行文件.COM文件源程序的特点是:第一条可执行指令的起始存放地址必须是100H,不能分段,不用定义堆栈,所有过程为NEAR类型,直接用INT20H指令返回DOS。
5.DOS功能调用与BIOS中断调用.二者都是完成DOS系统提供给用户的输入/输出等常用功能,通过执行软中断指令完成一次软中断服务。
.DOS功能调用的中断服务程序是操作系统的一部分,存于RAM中;而BIOS中断调用的中断服务程序存放在ROM中。
输入/输出与中断系统1.输入/输出的方式.程序直接I/O方式:用IN和OUT指令直接在端口级上进行I/O操作,数据传送方式分为无条件传送方式和查询传送方式。
.中断传送方式:由CPU响应中断请求完成中断服务。
.DMA传送方式:直接在存储器与外设之间传送数据。
2.有关中断的概念.中断、中断源、中断请求、中断服务、中断向量、中断向量表、中断响应过程、中断指令、开中断、关中断、内部中断、外部中断、可屏蔽中断、非屏蔽中断。
3.键盘I/O、显示器I/O操作.键盘的输入操作用BIOS的16H中断调用控制,也可直接访问60H端口(数据端口),61H端口(状态端口)检测键盘的按键操作。
.对于特殊键(如Shift,Ctrl,Alt,NumLock,ScrollLock等键)的按动情况,可以直接从来40:17H单元取得有关信息。
.显示器的图形显示可以用BIOS的10H中断调用实现,另一种速度更快的方法是直接读写视频缓冲区。
4.打印机I/O操作由INT17H中断调用实现,串行通讯口操作由INT14H中断调用实现。
CLD Clear the direction flag(set to forward direction)将方向标志置0,使si和di增量,串处理从低地址向高地址处理8088汇编速查手册一、数据传输指令它们在存贮器和寄存器、寄存器和输入输出端口之间传送数据.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标志出栈.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时,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程序结束.。