- 浏览: 1784115 次
- 性别:
- 来自: 深圳
文章分类
- 全部博客 (528)
- java基础 (35)
- oracle (23)
- 项目管理 (10)
- 代码架构 (27)
- java线程与进程 (2)
- 盈利模式 (10)
- 性能测试 (1)
- Ophone (2)
- web (6)
- asp (0)
- php (1)
- c# (1)
- Ruby (0)
- jboss (4)
- java基础之面试篇 (7)
- 数据查询优化 (1)
- weblogic (3)
- EJB (1)
- EXT (6)
- jquery (8)
- struts2 (2)
- struts1 (1)
- css (1)
- javascript (4)
- SSI (9)
- linux (9)
- c++ (6)
- 网络安全 (3)
- swing (2)
- 嵌入式 (1)
- 图像处理(机器人智能技术) (1)
- vb (2)
- mysql (2)
- sqlserver (10)
- dephi (0)
- Android (4)
- hadoop (1)
- maven (4)
- mybatis (1)
- html5 (1)
- 算法 (0)
- 高并发架构总结 (1)
- 时事评论 (4)
- 有些话不能不说 (35)
- 琴棋书画 (0)
- 教育 (1)
- 创业需要的 (4)
- 产品经理需要的 (4)
- 小南那些青涩的文章 (9)
- 如何创新 (4)
- 历史借鉴之秦汉 (1)
- 历史借鉴之三国 (1)
- 历史借鉴之魏晋 (1)
- 历史借鉴之隋唐 (1)
- 历史借鉴之南北宋 (1)
- 历史借鉴之近现代史 (1)
- 好工具我来推荐 (4)
- 汇编 (14)
最新评论
-
bilimeng:
求教,ConcurrentHashMap不是线程安全的么,为啥 ...
架构师之jdk8-----------------ConcurrentHashMap快速构建本地缓存和单例模式 -
baiducctv5:
wtaisi 写道wtaisi 写道|||||||||
spring aop中的propagation的7种配置的意思 -
zhangdong92:
另外内存泄漏一般也不是指计算时溢出。而是指某些对象已经不再使用 ...
java基础之面试篇三---int,float,long,double取值范围,内存泄露 -
zhangdong92:
Long.MAX_VALUE应该是(2^63)-1,而不是64 ...
java基础之面试篇三---int,float,long,double取值范围,内存泄露 -
nannan408:
java-lxm 写道好湿好湿好湿谢谢: )。
游南巅之晚秋
一、常用的指令----------------------------------------------------------
AAA
未组合的十进制加法调整指令 AAA(ASCII Adgust for Addition)
格式: AAA
功能: 对两个组合的十进制数相加运算(存在AL中)的结果进行调整,产生一个未组合的十进制数放在AX中.
说明:
1. 组合的十进制数和未组合的十进制数:在计算中,十进制数可用四位二进制数编码,称为BCD码.
当一个节(8位)中存放一位BCD码,且放在字节的低4位, 高4位为时称为未组合的BCD码.
2. AAA的调整操作
若(AL) and 0FH>9 或 AF=1,则调整如下:
(AL)<--(AL)+6,(AH)<--(AH)+1,AF=1,CF<--AF,(AL)<--(AL) and 0FH
AAD
未组合十进制数除法调整指令 AAD(ASCII Adjust for Division)
格式: AAD
功能: 在除法指令前对AX中的两个未组合十进制数进行调整,以便能用DIV指令实现两个未组合的十进制数的除法运算,其结果为未组合的十进制数,商(在AL中)和余数(在AH中).
说明:
1. AAD指令是在执行除法DIV之前使用的,以便得到二进制结果存于AL中,然后除以OPRD,得到的商在AL中,余数在AH中.
2. 示例: MOV BL,5
MOV AX,0308H
AAD ;(AL)<--1EH+08H=26H,(AH)<--0
DIV BL ;商=07H-->(AL),余数=03H-->(AH).
AAM
未组合十进制数乘法调整指令 AAM(ASCII Adjust MULtiply)
格式: AAM
功能: 对两个未组合的十进制数相乘后存于AX中的结果进行调整,产生一个未组合的十进制数存在AL中.
说明:
1. 实际上是两个未组合的十进制数字节相乘,一个0~9的数与另一个0~9的数相乘其积最大为81.为了得到正确的结果,应进行如下调整:
乘积: (AH)<--(AL)/10
(AL)<--(AL)MOD10
2. 本指令应跟在MUL指令后使用,乘积的两位十进制结果,高位放在AH中,低位放在AL中.AH内容是MUL指令的结果被10除的商,即(AL)/10,而最后的AL内容是乘积被10整除的余数(即个位数).
AAS
未组合十进制减法调整指令 AAS(ASCII Adjust for Subtraction)
格式: AAS
功能: 对两个未组合十进制数相减后存于AL中的结果进行调整,调整后产生一个未组合的十进制数数且仍存于AL中.
说明:
1. 本指令影响标志位CF及AF.
2. 调整操作
若(AL) and 0FH > 9 或 AF=1
则(AL)<--(AL)-6,(AH)<--(AH)-1,CF<--AF,(AL)<--(AL) and 0FH,
否则(AL)<--(AL) and 0FH
ADC
带进位加法指令 ADC(Addition Carry)
格式: ADC OPRD1,OPRD2
功能: OPRD1<--OPRD1 + OPRD2 + CF
说明:
1. OPRD1为任一通用寄存器或存储器操作数,可以是任意一个通用寄存器,而且还可以是任意一个存储器操作数.
OPRD2为立即数,也可以是任意一个通用寄存器操作数.立即数只能用于源操作数.
2. OPRD1和OPRD2均为寄存器是允许的,一个为寄存器而另一个为存储器也是允许的,但不允许两个都是存储器操作数.
3. 加法指令运算的结果对CF、SF、OF、PF、ZF、AF都会有影响.以上标志也称为结果标志.
4. 该指令对标志位的影响同ADD指令.
ADD
加法指令 ADD(Addition)
格式: ADD OPRD1,OPRD2
功能: 两数相加
说明:
1. OPRD1为任一通用寄存器或存储器操作数,可以是任意一个通用寄存器,而且还可以是任意一个存储器操作数.
OPRD2为立即数,也可以是任意一个通用寄存器操作数.立即数只能用于源操作数.
2. OPRD1和OPRD2均为寄存器是允许的,一个为寄存器而另一个为存储器也是允许的, 但不允许两个都是存储器操作数.
3. 加法指令运算的结果对CF、SF、OF、PF、ZF、AF都会有影响.以上标志也称为结果标志.加法指令适用于无符号数或有符号数的加法运算.
AND
逻辑与运算指令 AND
格式: AND OPRD1,OPRD2
功能: 对两个操作数实现按位逻辑与运算,结果送至目的操作数.本指令可以进行字节或字的‘与’运算,
OPRD1<--OPRD1 and OPRD2.
说明:
1. 目的操作数OPRD1为任一通用寄存器或存储器操作数.源操作数OPRD2为立即数,任一通用寄存器或存储器操作数.
2. 示例: AND AL,0FH ;(AL)<--(AL) AND 0FH
AND AX,BX ;(AX)<--(AX) AND (BX)
AND DX,BUFFER[SI+BX]
AND BETA[BX],00FFH
注意: 两数相与,有一个数假则值为假
CALL
过程调用指令 CALL
格式: CALL OPRD
功能: 过程调用指令
说明:
1. 其中OPRD为过程的目的地址.
2. 过程调用可分为段内调用和段间调用两种.寻址方式也可以分为直接寻址和间接寻址两种.
3. 本指令不影响标志位.
CBW
字节扩展指令 CBW(Convert Byte to Word)
格式: CBW
功能: 将字节扩展为字,即把AL寄存器的符号位扩展到AH中.
说明:
1. 两个字节相除时,先使用本指令形成一个双字节长的被除数.
2. 本指令不影响标志位.
3. 示例: MOV AL,25
CBW
IDIV BYTE PTR DATA1
CLC
处理器控制指令-标志位操作指令
格式:
CLC ;置CF=0
STC ;置CF=1
CMC ;置CF=(Not CF)进位标志求反
CLD ;置DF=0
STD ;置DF=1
CLI ;置IF=0,CPU禁止响应外部中断
STI ;置IF=1,使CPU允许向应外部中断
功能: 完成对标志位的置位、复位等操作.
说明: 例如串操作中的程序,经常用CLD指令清方向标志使DF=0,在串操作指令执行时,按增量的方式修改吕指针.
CLD
处理器控制指令-标志位操作指令
格式:
CLC ;置CF=0
STC ;置CF=1
CMC ;置CF=(Not CF)进位标志求反
CLD ;置DF=0
STD ;置DF=1
CLI ;置IF=0,CPU禁止响应外部中断
STI ;置IF=1,使CPU允许向应外部中断
功能: 完成对标志位的置位、复位等操作.
说明: 例如串操作中的程序,经常用CLD指令清方向标志使DF=0,在串操作指令执行时,按增量的方式修改吕指针.
CLI
处理器控制指令-标志位操作指令
格式:
CLC ;置CF=0
STC ;置CF=1
CMC ;置CF=(Not CF)进位标志求反
CLD ;置DF=0
STD ;置DF=1
CLI ;置IF=0,CPU禁止响应外部中断
STI ;置IF=1,使CPU允许向应外部中断
功能: 完成对标志位的置位、复位等操作.
说明: 例如串操作中的程序,经常用CLD指令清方向标志使DF=0,在串操作指令执行时,按增量的方式修改吕指针.
CMC
处理器控制指令-标志位操作指令
格式:
CLC ;置CF=0
STC ;置CF=1
CMC ;置CF=(Not CF)进位标志求反
CLD ;置DF=0
STD ;置DF=1
CLI ;置IF=0,CPU禁止响应外部中断
STI ;置IF=1,使CPU允许向应外部中断
功能: 完成对标志位的置位、复位等操作.
说明: 例如串操作中的程序,经常用CLD指令清方向标志使DF=0,在串操作指令执行时,按增量的方式修改吕指针.
CMP
比效指令 CMP(CoMPare)
格式: CMP OPRD1,OPRD2
功能: 对两数进行相减,进行比较.
说明:
1. OPRD1为任意通用寄存器或存储器操作数.
OPRD2为任意通用寄存器或存储器操作数,立即数也可用作源操作数OPRD2.
2. 对标志位的影响同SUB指令,完成的操作与SUB指令类似,唯一的区别是不将OPRD1-OPRD2的结果送回OPRD1,而只是比较.
3. 在8088/8086指令系统中,专门提供了一组根据带符号数比较大小后,实现条件转移的指令.
CMPS
字符串比较指令
格式: CMPS OPRD1,OPRD2
CMPSB
CMPSW
功能: 由SI寻址的源串中数据与由DI寻址的目的串中数据进行比较,比较结果送标志位,而不改变操作数本身.
同时SI,DI将自动调整.
说明:
1. 其中OPRD2为源串符号地址,OPRD1为目的串符号地址.
2. 本指令影响标志位AF、CF、OF、SF、PF、ZF.本指令可用来检查二个字符串是否相同,可以使用循环控制方法对整串进行比较.
3. 与MOVS相似,CMPS指令也可以不使用操作数,此时可用指令CMPSB或CMPSW分别表示字节串比较或字串比较.
CMPSB
字符串比较指令
格式: CMPS OPRD1,OPRD2
CMPSB
CMPSW
功能: 由SI寻址的源串中数据与由DI寻址的目的串中数据进行比较,比较结果送标志位,而不改变操作数本身.
同时SI,DI将自动调整.
说明:
1. 其中OPRD2为源串符号地址,OPRD1为目的串符号地址.
2. 本指令影响标志位AF、CF、OF、SF、PF、ZF.本指令可用来检查二个字符串是否相同,可以使用循环控制方法对整串进行比较.
3. 与MOVS相似,CMPS指令也可以不使用操作数,此时可用指令CMPSB或CMPSW分别表示字节串比较或字串比较.
CMPSW
字符串比较指令
格式: CMPS OPRD1,OPRD2
CMPSB
CMPSW
功能: 由SI寻址的源串中数据与由DI寻址的目的串中数据进行比较,比较结果送标志位,而不改变操作数本身.
同时SI,DI将自动调整.
说明:
1. 其中OPRD2为源串符号地址,OPRD1为目的串符号地址.
2. 本指令影响标志位AF、CF、OF、SF、PF、ZF.本指令可用来检查二个字符串是否相同,可以使用循环控制方法对整串进行比较.
3. 与MOVS相似,CMPS指令也可以不使用操作数,此时可用指令CMPSB或CMPSW分别表示字节串比较或字串比较.
CWD
字扩展指令 CWD(Convert Word to Double Word)
格式: CWD
功能: 将字扩展为双字长,即把AX寄存器的符号位扩展到DX中.
说明:
1. 两个字或字节相除时,先用本指令形成一个双字长的的被除数.
2. 本指令不影响标志位.
3. 示例: 在B1、B2、B3字节类型变量中,分别存有8们带符号数a、b、c,实现(a*b+c)/a运算。
DAA
组合的十进制加法调整指令 DAA(Decimal Adjust for Addition)
格式: DAA
功能: 对AL中的两个组合进制数相加的结果进行调整,调整结果仍放在AL中,进位标志放在CF中.
说明:
1. 调整操作如下
(1) 若(AL) and 0FH>9 或 AF=1,则(AL)<--(AL)+6,AF<--1,对低四位的调整.
(2) 若(AL) and 0F0H>90H 或 CF=1,则(AL)<--(AL)+60H,CF<--1.
2. 示例: (AL)=18H,(BL)=06H
ADD AL,BL ; (AL)<--(AL)+(BL) ; (AL)=1EH
DAA ; (AL)
DAS
组合十进制减法调整指令 DAS(Decimal Adjust for Subtraction)
格式: DAS
功能: 对两个组合十进制数相减后存于AL中的结果进行调整,调整后产生一个组合的十进制数且仍存于AL中.
说明:
调整操作
若(AL) and 0FH > 9 或 AF=1,则(AL)<--(AL)-6,AF=1
若(AL) and 0F0H > 90H 或 CF=1,则(AL)<--(AL)-60,CF=1
DEC
减一指令 DEC(Decrement by 1)
格式: DEC OPRD
功能: OPRD<--OPRD-1
说明:
1. OPRD 为寄存器或存储器操作数.
2. 这条指令执行结果影响AF、OF、PF、SF、ZF标志位,但不影响CF标志位.
3. 示例 DEC AX
DEC CL
DEC WORD PTR[DI]
DEC ALFA[DI+BX]
DIV
无符号数除法指令 DIV(DIVision)
格式: DIV OPRD
功能: 实现两个无符号二进制数除法运算.
说明:
1. 其中OPRD为任一个通用寄存器或存储器操作数.
2. 字节相除,被除数在AX中;字相除,被除数在DX,AX中,除数在OPRD中.
字节除法: (AL)<--(AX)/OPRD,(AH)<--(AX)MOD OPRD
字除法: (AX)<--(DX)(AX)/OPRD,(DX)<--(DX)(AX) MOD OPRD
ESC
处理器交权指令 ESC
格式: ESC EXTOPRD,OPRD
功能: 使用本指令可以实现协处理器出放在ESC指令代码中的6位常数,该常数指明协处理器要完成的功能.
当源操作数为存储器变量时,则取出该存储器操作数传送给协处理器.
说明:
1. 其中EXTOPRD为外部操作码,OPRD为源操作数.
2. 本指不影响标志位.
HLT
处理器暂停指令 HLT
格式: HLT
功能: 使处理器处于暂时停机状态.
说明:
1. 本指令不影响标志位.
2. 由执行HLT引起的暂停,只有RESET(复位)、NMI(非屏蔽中断请求)、INTR(可屏蔽的外部中断请求)信号可以使
其退出暂停状态.它可用于等待中断的到来或多机系统的同步操作.
IDIV
带符号数除法指定 IDIV(Interger DIVision)
格式: IDIV OPRD
功能: 这实现两个带符号数的二进制除法运算.
说明:
1. 其中OPRD为任一通用寄存器或存储器操作数.
2. 理由与IMUL相同,只有IDIV指令,才能得到符号数相除的正确结果.
3. 当被除数为8位,在进行字节除法前,应把AL的符号位扩充至AH中.在16位除法时,若被除数为16位,则应将AX中的符号位扩到DX中.
IMUL
带符号数乘法指令 IMUL(Integer MULtiply)
格式: IMUL OPRD
功能: 完成两个带符号数的相乘
说明:
1. 其中OPRD为任一通用寄存器或存储器操作数.
2. MUL指令对带符号相乘时,不能得到正确的结果.
例如: (AL)=255
(CL)=255
MUL CL
(AX)=65025
注意: 这对无符号数讲,结果是正确的,但对带符号数讲,相当于(-1)*(-1)结果应为+1,而65025对应的带符号数为-511,显然是不正确的.
IN
输入指令 IN
格式: IN AL,n ;(AL)<--(n)
IN AX,n ;(AX)<--(n+1),(n)
IN AL,DX ;(AL)<--[(DX)]
IN AX,DX ;(AX)<--[(DX)+1],[(DX)]
功能: 输入指令
说明:
1. 其中n为8位的端口地址,当字节输入时,将端口地址n+1的内容送至AH中,端口地址n的内容送AL中.
2. 端口地址也可以是16位的,但必须将16位的端口地址送入DX中.当字节寻址时,由DX内容作端口地址的内容送至AL中;
当输入数据字时,[(DX)+1]送AH,[(DX)]送AL中,用符号:(AX)<--[(DX)+1],[(DX)]表示.
INC
加1指令 INC(INCrement by 1)
格式: INC OPRD
功能: OPRD<--OPRD+1
说明:
1. OPRD 为寄存器或存储器操作数.
2. 这条指令执行结果影响AF、OF、PF、SF、ZF标志位,但不影响CF标志位.
3. 示例:
INC SI;(SI)<--(SI)+1
INC WORD PTR[BX]
INC BYTE PTR[BX+DI]
INC CL;(CL)<--(CL)+1
注意: 上述第二,三两条指令,是对存储字及存储字节的内容加1以替代原来的内容.
INT
软中断指令 INT
格式: INT n 其中n为软中断的类型号.
功能: 本指令将产生一个软中断,把控制转向一个类型号为n的软中断,该中断处理程序入口地址在中断向量表的n*4地址
处的二个存储器字(4个单元)中.
说明: 操作过程与INTO指令雷同,只需将10H改为n*4即可.所以,本指令也将影响标志位IF及TF.
INTO
溢出中断指令 INTO(INTerrupt if Overflow)
格式: INTO
功能: 本指令检测OF标志位,当OF=1时,说明已发生溢出,立即产生一个中断类型4的中断,当OF=0时,本指令不起作用.
说明:
1. 本指令影响标志位IF及TF.
2. 本指令可用于溢出处理,当OF=1时,产生一个类型4的软中断.在中断处理程序中完成溢出的处理操作.
IRET
中断返回指令 IRET
格式: IRET
功能: 用于中断处理程序中,从中断程序的断点处返回,继续执行原程序.
说明:
1. 本指令将影响所有标志位.
2. 无论是软中断,还是硬中断,本指令均可使其返回到中断程序的断点处继续执行原程序.
JA
条件转移指令JA/JNBE
格式: JA/JNBE标号
功能: 为高于/不低于等于的转移指令
说明:
1. 例如两个符号数a,b比较时,a>b(即CF=0,ZF=0)时转移.因为单一标志位CF=0,只表示a>=b.
2. JA/JNBE是同一条指令的两种不同的助记符.
3. 该指令用于无符号数进行条件转移
JAE
条件转移指令JAE/JNB
格式: JAE/JNB 标号
功能: 为高于等于/不低于的转移指令
说明:
1. JAE/JNB是同一条指令的两种不同的助记符.
2. 该指令用于无符号数进行条件转移.
JB
条件转移指令JB/JNAE
格式: JB/JNAE 标号
功能: 低于/不高于等于时转移
说明: 该指令用于无符号数的条件转移
JBE
条件转移指令JBE/JNA
格式: JBE/JNA 标号
功能: 低于等于/不高于时转移
说明: 该指令用于无符号数的条件转移
JC
条件转移指令 JC
格式: JC 标号
功能: CF=1,转至标号处执行
说明: JC为根据标志位CF进行转移的指令
JE
条件转移指令JE/JZ
格式: JE/JZ标号
功能: ZF=1,转至标号处执
说明:
1. 指令JE与JZ等价,它们是根据标志位ZF进行转移的指令
2. JE,JZ均为一条指令的两种助记符表示方法
JG
条件转移指令JG/JNLE
格式: JG/JNLE 标号
功能: 大于/不小于等于时转移
说明: 用于带符号数的条件转移指令
JGE
条件转移指令JGE/JNL
格式: JGE/JNL标号
功能: 大于等于/不小于时转移
说明: 用于带符号数的条件转移指令
JL
条件转移指令JL/JNGE
格式: JL/JNGE标号
功能: 小于/不大于等于时转移
说明: 用于带符号数的条件转移指令
JLE
条件转移指令JLE/JNG
格式: JLE/JNG 标号
功能: 小于等于/不大于时转移
说明: 用于带符号数的条件转移指令
JMP
无条件转移指令JMP
格式: JMP OPRD
功能: JMP指令将无条件地控制程序转移到目的地址去执行.当目的地址仍在同一个代码段内,称为段内转移;当目标地址不在同一个代码段内,则称为段间转移.这两种情况都将产生不同的指令代码,以便能正确地生成目的地址,在段内转移时,指令只要能提供目的地址的段 内偏移量即够了;而在段间转移时,指令应能提供目的地址的段地址及段内偏移地址值.
说明:
1. 其中OPRD为转移的目的地址.程序转移到目的地址所指向的指令继续往下执行.
2. 本组指令对标志位无影响.
3. <1> 段内直接转移指令: JMP NEAR 标号
<2> 段内间接转移指令: JMP OPRD
<3> 段间直接转移指令: JMP FAR 标号
<4> 段间间接转移指令:JMP OPRD其中的OPRD为存储器双字操作数.段间间接转移只能通过存储器操作数来实现.
JNA
条件转移指令JBE/JNA
格式: JBE/JNA 标号
功能: 低于等于/不高于时转移
说明: 该指令用于无符号数的条件转移
JNAE
条件转移指令JB/JNAE
格式: JB/JNAE 标号
功能: 低于/不高于等于时转移
说明: 该指令用于无符号数的条件转移
JNB
条件转移指令JAE/JNB
格式: JAE/JNB 标号
功能: 为高于等于/不低于的转移指令
说明:
1. JAE/JNB是同一条指令的两种不同的助记符.
2. 该指令用于无符号数进行条件转移.
JNBE
条件转移指令JA/JNBE
格式: JA/JNBE标号
功能: 为高于/不低于等于的转移指令
说明:
1. 例如两个符号数a,b比较时,a>b(即CF=0,ZF=0)时转移.因为单一标志位CF=0,只表示a>=b.
2. JA/JNBE是同一条指令的两种不同的助记符.
3. 该指令用于无符号数进行条件转移
JNC
条件转移指令JNC
格式: JNC标号
功能: CF=0,转至标号处执行
说明: JNC为根据标志位CF进行转移的指令
JNE
条件转移指令JNE/JNZ
格式: JNE/JNZ 标号
功能: ZF=0,转至标号处执行
说明:
1. 指令JNE与JNZ等价,它们是根据标志位ZF进行转移的指令
2. JNE,JNZ均为一条指令的两种助记符表示方法
JNG
条件转移指令JLE/JNG
格式: JLE/JNG 标号
功能: 小于等于/不大于时转移
说明: 用于带符号数的条件转移指令
JNGE
条件转移指令JL/JNGE
格式: JL/JNGE标号
功能: 小于/不大于等于时转移
说明: 用于带符号数的条件转移指令
JNL
条件转移指令JGE/JNL
格式: JGE/JNL标号
功能: 大于等于/不小于时转移
说明: 用于带符号数的条件转移指令
JNLE
条件转移指令JG/JNLE
格式: JG/JNLE 标号
功能: 大于/不小于等于时转移
说明: 用于带符号数的条件转移指令
JNO
条件转移指令JNO
格式: JNO 标号
功能: OF=0,转至标号处执行
说明: JNO是根椐溢出标志位OF进行转移的指令
JNP
条件转移指令JNP/JPO
格式: JNP/JPO 标号
功能: PF=0,转至标号处执行
说明:
1. 指令JNP与JPO,它们是根据奇偶标志位PF进行转移的指令
2. JNP,JPO均为一条指令的两种助记符表示方法
JNS
条件转移指令JNS
格式: JNS 标号
功能: SF=0,转至标号处执行
说明: JNS是根据符号标志位SF进行转移的指令
JNZ
条件转移指令JNE/JNZ
格式: JNE/JNZ 标号
功能: ZF=0,转至标号处执行
说明:
1. 指令JNE与JNZ等价,它们是根据标志位ZF进行转移的指令
2. JNE,JNZ均为一条指令的两种助记符表示方法
JO
条件转移指令JO
格式: JO 标号
功能: OF=1,转至标号处执行
说明: JO是根椐溢出标志位OF进行转移的指令
JP
条件转移指令JP/JPE
格式: JP/JPE 标号
功能: PF=1,转至标号处执行
说明:
1. 指令JP与JPE,它们是根据奇偶标志位PF进行转移的指令
2. JP,JPE均为一条指令的两种助记符表示方法
JPE
条件转移指令JP/JPE
格式: JP/JPE 标号
功能: PF=1,转至标号处执行
说明:
1. 指令JP与JPE,它们是根据奇偶标志位PF进行转移的指令
2. JP,JPE均为一条指令的两种助记符表示方法
JPO
条件转移指令JNP/JPO
格式: JNP/JPO 标号
功能: PF=0,转至标号处执行
说明:
1. 指令JNP与JPO,它们是根据奇偶标志位PF进行转移的指令
2. JNP,JPO均为一条指令的两种助记符表示方法
JS
条件转移指令JS
格式: JS 标号
功能: SF=1,转至标号处执行
说明: JS是根据符号标志位SF进行转移的指令
JZ
条件转移指令JE/JZ
格式: JE/JZ标号
功能: ZF=1,转至标号处执
说明:
1. 指令JE与JZ等价,它们是根据标志位ZF进行转移的指令
2. JE,JZ均为一条指令的两种助记符表示方法
LAHF
标志传送指令 LAHF
格式: LAHF
功能: 取FLAG标志寄存器低8位至AH寄存器.(AH)<--(FLAG)7~0
说明: 该指令不影响FLAG的原来内容,AH只是复制了原FLAG的低8位内容.
LDS
从存储器取出32位地址的指令 LDS
格式: LDS OPRD1,OPRD2
功能: 从存储器取出32位地址的指令.
说明:
OPRD1 为任意一个16位的寄存器.
OPRD2 为32位的存储器地址.
示例: LDS SI,ABCD
LDS BX,FAST[SI]
LDS DI,[BX]
注意: 上面LDS DI,[BX]指令的功能是把BX所指的32位地址指针的段地址送入DS,偏移地址送入DI.
LEA
有效地址传送指令 LEA
格式: LEA OPRD1,OPRD2
功能: 将源操作数给出的有效地址传送到指定的的寄存器中.
说明:
1. OPRD1 为目的操作数,可为任意一个16位的通用寄存器.
OPRD2 为源操作数,可为变量名、标号或地址表达式.
示例: LEA BX,DATA1
LEA DX,BETA[BX+SI]
LEA BX BX,[BP],[DI]
2. 本指令对标志位无影响。
LES
从存储器取出32位地址的指令 LES
格式: LES OPRD1,OPRD2
功能: 从存储器取出32位地址的指令.
说明:
OPRD1 为任意一个16位的寄存器.
OPRD2 为32位的存储器地址.
示例: LES SI,ABCD
LES BX,FAST[SI]
LES DI,[BX]
注意: 上面LES DI,[BX]指令的功能是把BX所指的32位地址指针的段地址送入ES,偏移地址送入DI.
LOCK
封锁总线指令 LOCK
格式: LOCK
功能: 指令是一个前缀,可放在指令的前面,告诉CPU在执行该指令时,不允许其它设备对总线进行访问.
无可用信息!用户可自行添加!
LODS
取字符串元素指令 LODS
格式: LODS OPRD 其中OPRD为源字符串符号地址.
功能: 把SI寻址的源串的数据字节送AL或数据字送AX中去, 并根据DF的值修改地址指针SI进行自动调整.
说明:
1. 本指令不影响标志位.
2. 当不使用操作数时,可用LODS(字节串)或LODSW(字串)指令.
LOOP
循环控制指令LOOP
格式: LOOP 标号
功能: (CX)<--(CX)-1,(CX)<>0,则转移至标号处循环执行, 直至(CX)=0,继续执行后继指令.
说明:
1. 本指令是用CX寄存器作为计数器,来控制程序的循环.
2. 它属于段内SHORT短类型转移,目的地址必须距本指令在-128到+127个字节的范围内.
LOOPE
循环控制指令LOOPZ/LOOPE
格式: LOOPZ/LOOPE 标号
功能: (CX)<--(CX)-1,(CX)<>0 且ZF=1时,转至标号处循环
说明:
1. 本指令是用CX寄存器作为计数器,来控制程序的循环.
2. 它属于段内SHORT短类型转移,目的地址必须距本指令在-128到+127个字节的范围内.
3. 以上两种助记符等价.
LOOPNE
循环控制指令LOOPNZ/LOOPNE
格式: LOOPNZ/LOOPNE 标号
功能: (CX)<--(CX)-1,(CX)<>0 且ZF=0时,转至标号处循环
说明:
1. 本指令是用CX寄存器作为计数器,来控制程序的循环.
2. 它属于段内SHORT短类型转移,目的地址必须距本指令在-128到+127个字节的范围内.
3. 以上两种助记符等价.
LOOPNZ
循环控制指令LOOPNZ/LOOPNE
格式: LOOPNZ/LOOPNE 标号
功能: (CX)<--(CX)-1,(CX)<>0 且ZF=0时,转至标号处循环
说明:
1. 本指令是用CX寄存器作为计数器,来控制程序的循环.
2. 它属于段内SHORT短类型转移,目的地址必须距本指令在-128到+127个字节的范围内.
3. 以上两种助记符等价.
LOOPZ
循环控制指令LOOPZ/LOOPE
格式: LOOPZ/LOOPE 标号
功能: (CX)<--(CX)-1,(CX)<>0 且ZF=1时,转至标号处循环
说明:
1. 本指令是用CX寄存器作为计数器,来控制程序的循环.
2. 它属于段内SHORT短类型转移,目的地址必须距本指令在-128到+127个字节的范围内.
3. 以上两种助记符等价.
MOVE
数据传送指令 MOV
格式: MOV OPRD1,OPRD2
功能: 本指令将一个源操作数送到目的操作数中,即OPRD1<--OPRD2.
说明:
1. OPRD1 为目的操作数,可以是寄存器、存储器、累加器.
OPRD2 为源操作数,可以是寄存器、存储器、累加器和立即数.
2. MOV 指令以分为以下四种情况:
<1> 寄存器与寄存器之间的数据传送指令
<2> 立即数到通用寄存器数据传送指令
<3> 寄存器与存储器之间的数据传送指令
<4> 立即数到存储器的数据传送
3. 本指令不影响状态标志位
MOVS
字符串传送指令 MOVS
格式: MOVS OPRD1,OPRD2
MOVSB
MOVSW
功能: OPRD1<--OPRD2.
说明:
1. 其中OPRD2为源串符号地址,OPRD1为目的串符号地址.
2. 字节串操作: 若DF=0,则作加, 若DF=1,则作减.
3. 对字串操作时: 若DF=0,则作加,若DF=1,则作减,.
4. 在指令中不出现操作数时,字节串传送格式为MOVSB、字串传送格式为MOVSW.
5. 本指令不影响标志位.
MOVSB
字符串传送指令 MOVS
格式: MOVS OPRD1,OPRD2
MOVSB
MOVSW
功能: OPRD1<--OPRD2.
说明:
1. 其中OPRD2为源串符号地址,OPRD1为目的串符号地址.
2. 字节串操作: 若DF=0,则作加, 若DF=1,则作减.
3. 对字串操作时: 若DF=0,则作加,若DF=1,则作减,.
4. 在指令中不出现操作数时,字节串传送格式为MOVSB、字串传送格式为MOVSW.
5. 本指令不影响标志位.
MOVSW
字符串传送指令 MOVS
格式: MOVS OPRD1,OPRD2
MOVSB
MOVSW
功能: OPRD1<--OPRD2.
说明:
1. 其中OPRD2为源串符号地址,OPRD1为目的串符号地址.
2. 字节串操作: 若DF=0,则作加, 若DF=1,则作减.
3. 对字串操作时: 若DF=0,则作加,若DF=1,则作减,.
4. 在指令中不出现操作数时,字节串传送格式为MOVSB、字串传送格式为MOVSW.
5. 本指令不影响标志位.
MUL
无符号数乘法指令 MUL(MULtiply)
格式: MUL OPRD
功能: 乘法操作.
说明:
1. OPRD为通用寄存器或存储器操作数.
2. OPRD为源操作数,即作乘数.目的操作数是隐含的,即被乘数总是指定为累加器AX或AL的内容.
3. 16位乘法时,AX中为被乘数.8位乘法时,AL为被乘数.当16位乘法时,32位的乘积存于DX及AX中;8位乘法的16位乘积存于AX中.
4. 操作过程: 字节相乘:(AX)<--(AL)*OPRD,当结果的高位字节(AH)不等于0时,则CF=1、OF=1.
NEG
取补指令 NEG(NEGate)
格式: NEG OPRD
功能: 对操作数OPRD进行取补操作,然后将结果送回OPRD.取补操作也叫作求补操作,就是求一个数的相反数的补码.
说明:
1. OPRD为任意通用寄存器或存储器操作数.
2. 示例: (AL)=44H,取补后,(AL)=0BCH(-44H).
3. 本指令影响标志位CF、OF、SF、PF、ZF及AF.
NOP
空操作指令 NOP
格式: NOP
功能: 本指令不产生任何结果,仅消耗几个时钟周期的时间,接着执行后续指令,常用于程序的延时等.
说明: 本指令不影响标志位.
NOT
逻辑非运算指令 NOT
格式: NOT OPRD
功能: 完成对操作数按位求反运算(即0变1,1变0),结果关回原操作数.
说明:
1. 其中OPRD可为任一通用寄存器或存储器操作数.
2. 本指梳令可以进行字或字节‘非’运算.
3. 本指令不影响标志位.
OR
逻辑或指令 OR
格式: OR OPRD1,OPRD2
功能: OR指令完成对两个操作数按位的‘或’运算,结果送至目的操作数中,本指令可以进行字节或字的‘或’运算.
OPRD1<--OPRD1 OR OPRD2.
说明:
1. 其中OPRD1,OPRD2含义与AND指令相同,对标志位的影响也与AND指令相同.
2. 两数相或,有一个数为真则值为真.
OUT
输出指令 OUT
格式: OUT n,AL ;(n)<--(AL)
功能: 输出指令
说明:
1. OUT n,AX ;(n+1),(n)<--(AX)
OUT DX,AL ;[(DX)]<--(AL)
OUT DX,AX ;[(DX)+1],[(DX)]<--(AX)
2. 输入指令及输出指令对标志位都不影响.
POP
堆栈操作指令 PUSH和POP
格式: PUSH OPRD
POP OPRD
功能: 实现压入操作的指令是PUSH指令;实现弹出操作的指令是POP指令.
说明:
1. OPRD为16位(字)操作数,可以是寄存器或存储器操作数.
2. POP指令的操作过程是: POP OPRD:OPRD<--((SP)),(SP)<--(SP)+2
它与压入操作相反,是先弹出栈顶的数顶,然后再修改指针SP的内容.
3. 示例: POP AX
POP DS
POP DATA1 POP ALFA[BX][DI]
4. PUSH和POP指令对状态标志位没有影响.
POPF
标志传送指令 POPF
格式: POPF
功能: 本指令的功能与PUSHF相反,在子程序调用和中断服务程序中,往往用PUSHF指令保护FLAG的内容,用POPF指令将保护的FLAG内容恢复.
说明: 如果对堆栈中的原FLAG内容进行修改,如对TF等标志位进行修改,然后再弹回标志位寄存器FLAG.这是通过指令修改TF标志的唯一方法.
PUSH
堆栈操作指令 PUSH和POP
格式: PUSH OPRD
POP OPRD
功能: 实现压入操作的指令是PUSH指令;实现弹出操作的指令是POP指令.
说明:
1. OPRD为16位(字)操作数,可以是寄存器或存储器操作数.
2. PUSH的操作过程是: (SP)<--(SP)-2,((sp))<--OPRD 即先修改堆栈指针SP(压入时为自动减2),然后,将指定的操作数送入新的栈顶位置.
此处的((SP))<--OPRD,也可以理解为: [(SS)*16+(SP)]<--OPRD 或 [SS:SP]<--OPRD
PUSHF
标志传送指令 PUSHF
格式: PUSHF
功能: 本指令可以把标志寄存器的内容保存到堆栈中去
RCL
循环移位指令
格式: ROL OPRD1,COUNT ;不含进位标志位CF在循环中的左循环移位指令.
ROR OPRD1,COUNT ;不含进位示志位CF在循环中的右循环移位指令.
RCL OPRD1,COUNT ;带进位的左循环移位指令.
RCR OPRD1,COUNT ;带进位的右循环移位指令.
说明:
1. 本指令组只影响标志CF、OF.OF由移入CF的内容决定,OF取决于移位一次后符号位是否改变,如改变,则OF=1.
2. 由于是循环移位,所以对字节移位8次; 对字移位16次,就可恢复为原操作数.由于带CF的循环移位,可以将CF的内容移入,
所以可以利用它实现多字节的循环.
RCR
循环移位指令
格式: ROL OPRD1,COUNT ;不含进位标志位CF在循环中的左循环移位指令.
ROR OPRD1,COUNT ;不含进位示志位CF在循环中的右循环移位指令.
RCL OPRD1,COUNT ;带进位的左循环移位指令.
RCR OPRD1,COUNT ;带进位的右循环移位指令.
说明:
1. 本指令组只影响标志CF、OF.OF由移入CF的内容决定,OF取决于移位一次后符号位是否改变,如改变,则OF=1.
2. 由于是循环移位,所以对字节移位8次; 对字移位16次,就可恢复为原操作数.由于带CF的循环移位,可以将CF的内容移入,所以可以利用它实现多字节的循环.
注意: 以上程序中的指令SHR AL,CL如改为SAR AL,CL,虽然最高4位可移入低4位,但最高位不为0,故应加入一条指令AND AL,0FH.否则,若最高位不为0时,将得到错误结果.
REP
重复前缀的说明
格式: REP ;CX<>0 重复执行字符串指令
REPZ/REPE ;CX<>0 且ZF=1重复执行字符串指令
REPNZ/REPNE ;CX<>0 且ZF=0重复执行字符串指令
功能: 在串操作指令前加上重复前缀,可以对字符串进重复处理.由于加上重复前缀后,对应的指令代码是不同的,所以指令的功能便具有重复处理的功能,重复的次数存放在CX寄存器中.
说明:
1. REP与MOVS或STOS串操作指令相结合使用,完成一组字符的传送或建立一组相同数据的字符串.
2. REPZ/REPE常用与CMPS串操作指令结合使用, 可以完成两组字符串的比较.
3. REPZ/REPE常与SCAS指令结合使用,可以完成在一个字符串中搜索一个关键字.
4. REPNZ/REPNE与CMPS指令结合使用,表示当串未结束(CX=1)且当对应串元素不相同(ZF=0)时,继续重复执行串比较指令.
REPE
重复前缀的说明
格式: REP ;CX<>0 重复执行字符串指令
REPZ/REPE ;CX<>0 且ZF=1重复执行字符串指令
REPNZ/REPNE ;CX<>0 且ZF=0重复执行字符串指令
功能: 在串操作指令前加上重复前缀,可以对字符串进重复处理.由于加上重复前缀后,对应的指令代码是不同的,所以指令的功能便具有重复处理的功能,重复的次数存放在CX寄存器中.
说明:
1. REPZ/REPE常用与CMPS串操作指令结合使用, 可以完成两组字符串的比较.
2. REPZ/REPE常与SCAS指令结合使用,可以完成在一个字符串中搜索一个关键字.
3. REPNZ/REPNE与CMPS指令结合使用,表示当串未结束(CX=1)且当对应串元素不相同(ZF=0)时,继续重复执行串比较指令.
4. REPNZ/REPNE与SCAS指令结合使用,表示串未结束(CX=1)且当关键字与串元素不相同(ZF=0)时,继续重复执行串搜索指令.
REPNE
重复前缀的说明
格式: REP ;CX<>0 重复执行字符串指令
REPZ/REPE ;CX<>0 且ZF=1重复执行字符串指令
REPNZ/REPNE ;CX<>0 且ZF=0重复执行字符串指令
说明:
1. REPZ/REPE常用与CMPS串操作指令结合使用, 可以完成两组字符串的比较.
2. REPZ/REPE常与SCAS指令结合使用,可以完成在一个字符串中搜索一个关键字.
3. REPNZ/REPNE与CMPS指令结合使用,表示当串未结束(CX=1)且当对应串元素不相同(ZF=0)时,继续重复执行串比较指令.
4. REPNZ/REPNE与SCAS指令结合使用,表示串未结束(CX=1)且当关键字与串元素不相同(ZF=0)时,继续重复执行串搜索指令.
REPNZ
重复前缀的说明
格式: REP ;CX<>0 重复执行字符串指令
REPZ/REPE ;CX<>0 且ZF=1重复执行字符串指令
REPNZ/REPNE ;CX<>0 且ZF=0重复执行字符串指令
说明:
1. REPZ/REPE常用与CMPS串操作指令结合使用, 可以完成两组字符串的比较.
2. REPZ/REPE常与SCAS指令结合使用,可以完成在一个字符串中搜索一个关键字.
3. REPNZ/REPNE与CMPS指令结合使用,表示当串未结束(CX=1)且当对应串元素不相同(ZF=0)时,继续重复执行串比较指令.
4. REPNZ/REPNE与SCAS指令结合使用,表示串未结束(CX=1)且当关键字与串元素不相同(ZF=0)时,继续重复执行串搜索指令.
REPZ
重复前缀的说明
格式: REP ;CX<>0 重复执行字符串指令
REPZ/REPE ;CX<>0 且ZF=1重复执行字符串指令
REPNZ/REPNE ;CX<>0 且ZF=0重复执行字符串指令
功能: 在串操作指令前加上重复前缀,可以对字符串进重复处理.由于加上重复前缀后,对应的指令代码是不同的,所以指令的功能便具有重复处理的功能,重复的次数存放在CX寄存器中.
说明:
1. REPZ/REPE常用与CMPS串操作指令结合使用, 可以完成两组字符串的比较.
2. REPZ/REPE常与SCAS指令结合使用,可以完成在一个字符串中搜索一个关键字.
3. REPNZ/REPNE与CMPS指令结合使用,表示当串未结束(CX=1)且当对应串元素不相同(ZF=0)时,继续重复执行串比较指令.
4. REPNZ/REPNE与SCAS指令结合使用,表示串未结束(CX=1)且当关键字与串元素不相同(ZF=0)时,继续重复执行串搜索指令.
RET
返回指令 RET
格式: RET
功能: 当调用的过程结束后实现从过程返回至原调用程序的下一条指令,本指令不影响标志位.
说明:
由于在过程定义时,已指明其近(NEAR)或远(FAR)的属性,所以RET指令根据段内调用与段间调用,执行不同的操作
对段内调用: 返回时,由堆栈弹出一个字的返回地址的段内偏移量至IP.
对段外调用: 返回时,由堆栈弹出的第一个字为返回地址的段内偏移量,将其送入IP中,由堆栈弹出第二个字为返回地址的段基址,将其送入CS中.
ROL
循环移位指令
格式: ROL OPRD1,COUNT ;不含进位标志位CF在循环中的左循环移位指令.
ROR OPRD1,COUNT ;不含进位示志位CF在循环中的右循环移位指令.
RCL OPRD1,COUNT ;带进位的左循环移位指令.
RCR OPRD1,COUNT ;带进位的右循环移位指令.
说明:
1. 本指令组只影响标志CF、OF.OF由移入CF的内容决定,OF取决于移位一次后符号位是否改变,如改变,则OF=1.
2. 由于是循环移位,所以对字节移位8次; 对字移位16次,就可恢复为原操作数.由于带CF的循环移位,可以将CF的内容移入,
所以可以利用它实现多字节的循环.
ROR
循环移位指令
格式:
ROL OPRD1,COUNT ;不含进位标志位CF在循环中的左循环移位指令.
ROR OPRD1,COUNT ;不含进位示志位CF在循环中的右循环移位指令.
RCL OPRD1,COUNT ;带进位的左循环移位指令.
RCR OPRD1,COUNT ;带进位的右循环移位指令.
说明:
1. 本指令组只影响标志CF、OF.OF由移入CF的内容决定,OF取决于移位一次后符号位是否改变,如改变,则OF=1.
2. 由于循环移位,所以对字节移位8次; 对字移位16次,可恢复为原操作数.
SAHF
标志传送指令 SAHF
格式: SAHF
功能: 将AH存至FLAG低8位
说明: 本指令将用AH的内容改写FLAG标志寄存器中的SF、ZF、AF、PF、和CF标志,从而改变原来的标志位.
SAL
算术左移指令 SAL(Shift Arithmetic Left)
格式: SAL OPRD1,COUNT
功能: 其中OPRD1,COUNT与指令SHL相同.本指令与SHL的功能也完全相同,这是因为逻辑左移指令与算术左移指令所要完成的操作是一样的.
说明:
1. 其中OPRD1为目的操作数,可以是通用寄存器或存储器操作数.
2. COUNT代表移位的次数(或位数).移位一次,COUNT=1;移位多于1次时,COUNT=(CL),(CL)中为移位的次数.
SAR
算术右移指令 SAR
格式: SAR OPRD1,COUNT
功能: 本指令通常用于对带符号数减半的运算中,因而在每次右移时,保持最高位(符号位)不变,最低位右移至CF中.
说明:
1. 其中OPRD1为目的操作数,可以是通用寄存器或存储器操作数.
2. COUNT代表移位的次数(或位数).移位一次,COUNT=1;移位多于1次时,COUNT=(CL),(CL)中为移位的次数.
SBB
带借位减去指令 SBB(SuBtraction with Borrow)
格式: SBB OPRD1,OPRD2
功能: 是进行两个操作数的相减再减去CF进位标志位,即从OPRD1<--OPRD1-OPRD2-CF,其结果放在OPDR1中.
说明:
示例 SBB DX,CX
SBB AX,DATA1
SBB BX,2000H
SBB ALFA[BX+SI],SI
SBB BETAP[DI,030AH
SCAS
字符串搜索指令 SCAS
格式: SCAS OPRD
SCASB
SCASW
功能: 把AL(字节串)或AX(字串)的内容与由DI寄存器寻址的目的串中的数据相减,结果置标志位,但不改变任一操作数本身.
地址指针DI自动调整.
说明:
1. 其中OPRD为目的串符号地址.
2. 本指令影响标志AF、CF、OF、PF、SF、ZF.该指令可查找字符串中的一个关键字,只需在本指令执行前,
把关键字放在AL(字节)或AX(字串 )中,用重复前缀可在整串中查找.
指令中不使用操作数时,可用指令格式SCASB,SCASW,分别表示字节串或字串搜索指令.
SCASB
字符串搜索指令 SCAS
格式: SCAS OPRD
SCASB
SCASW
功能: 把AL(字节串)或AX(字串)的内容与由DI寄存器寻址的目的串中的数据相减,结果置标志位,但不改变任一操作数本身.
地址指针DI自动调整.
说明:
1. 其中OPRD为目的串符号地址.
2. 本指令影响标志AF、CF、OF、PF、SF、ZF.该指令可查找字符串中的一个关键字,只需在本指令执行前,
把关键字放在AL(字节)或AX(字串 )中,用重复前缀可在整串中查找.
指令中不使用操作数时,可用指令格式SCASB,SCASW,分别表示字节串或字串搜索指令.
SCASW
字符串搜索指令 SCAS
格式: SCAS OPRD
SCASB
SCASW
功能: 把AL(字节串)或AX(字串)的内容与由DI寄存器寻址的目的串中的数据相减,结果置标志位,但不改变任一操作数本身.
地址指针DI自动调整.
说明:
1. 其中OPRD为目的串符号地址.
2. 本指令影响标志AF、CF、OF、PF、SF、ZF.该指令可查找字符串中的一个关键字,只需在本指令执行前,
把关键字放在AL(字节)或AX(字串 )中,用重复前缀可在整串中查找.
指令中不使用操作数时,可用指令格式SCASB,SCASW,分别表示字节串或字串搜索指令.
SHL
逻辑左移指令 SHL(Shift logical left)
格式: SHL OPRD1,COUNT
功能: 对给定的目的操作数左移COUNT次,每次移位时最高位移入标志位CF中,最低位补零.
说明:
1. 其中OPRD1为目的操作数,可以是通用寄存器或存储器操作数.
2. COUNT代表移位的次数(或位数).移位一次,COUNT=1;移位多于1次时,COUNT=(CL),(CL)中为移位的次数.
3. 例如: SHL AL,1
SHL CX,1
SHL ALFA[DI] 或者:
MOV CL,3
SHL DX,CL
SHL ALFA[DI],CL
SHR
逻辑右移指令 SHR
格式: SHR OPRD1,COUNT
功能: 本指令实现由COUNT决定次数的逻辑右移操作,每次移位时,最高位补0,最低位移至标志位CF中.
说明:
1. 其中OPRD1为目的操作数,可以是通用寄存器或存储器操作数.
2. COUNT代表移位的次数(或位数).移位一次,COUNT=1;移位多于1次时,COUNT=(CL),(CL)中为移位的次数.
3. 影响标志位OF,PF,SF,ZF,CF.
STC
处理器控制指令-标志位操作指令
格式:
CLC ;置CF=0
STC ;置CF=1
CMC ;置CF=(Not CF)进位标志求反
CLD ;置DF=0
STD ;置DF=1
CLI ;置IF=0,CPU禁止响应外部中断
STI ;置IF=1,使CPU允许向应外部中断
功能: 完成对标志位的置位、复位等操作.
说明: 例如串操作中的程序,经常用CLD指令清方向标志使DF=0,在串操作指令执行时,按增量的方式修改吕指针.
STD
处理器控制指令-标志位操作指令
格式:
CLC ;置CF=0
STC ;置CF=1
CMC ;置CF=(Not CF)进位标志求反
CLD ;置DF=0
STD ;置DF=1
CLI ;置IF=0,CPU禁止响应外部中断
STI ;置IF=1,使CPU允许向应外部中断
功能: 完成对标志位的置位、复位等操作.
说明: 例如串操作中的程序,经常用CLD指令清方向标志使DF=0,在串操作指令执行时,按增量的方式修改吕指针.
STI
处理器控制指令-标志位操作指令
格式:
CLC ;置CF=0
STC ;置CF=1
CMC ;置CF=(Not CF)进位标志求反
CLD ;置DF=0
STD ;置DF=1
CLI ;置IF=0,CPU禁止响应外部中断
STI ;置IF=1,使CPU允许向应外部中断
功能: 完成对标志位的置位、复位等操作.
说明: 例如串操作中的程序,经常用CLD指令清方向标志使DF=0,在串操作指令执行时,按增量的方式修改吕指针.
STOS
字符串存储指令 STOS
格式: STOS OPRD
功能: 把AL(字节)或AX(字)中的数据存储到DI为目的串地址指针所寻址的存储器单元中去.指针DI将根据DF的值进行自动调整.
说明:
1. 其中OPRD为目的串符号地址.
2. 本指令不影响标志位.当不使用操作数时,可用STOSB或STOSW分别表示字节串或字串的操作.
SUB
减法指令SUB(SUBtract)
格式: SUB OPRD1,OPRD2
功能: 两个操作数的相减,即从OPRD1中减去OPRD2,其结果放在OPDR1中.
说明:
示例 SUB DX,CX
SUB [BX+25],AX
SUB DI,ALFA[SI]
SUB CL,20
SUB DATA1[DI][BX],20A5H
TEST
测试指令 TEST
格式: TEST OPRD1,OPRD2
功能: 其中OPRD1、OPRD2的含义同AND指令一样,也是对两个操作数进行按位的'与'运算,唯一不同之处是不将'与'的结
果送目的操作数,即本指令对两个操作数 的内容均不进行修改,仅是在逻辑与操作后,对标志位重新置位.
说明: TEST与AND指令的关系,有点类似于CMP与SUB指令之间的关系.
WAIT
处理器等待指令 WAIT
格式: WAIT
功能: 本指令将使处理器检测TEST端脚,当TEST有效时,则退出等待状态执行下条指令,否则处理器处于等待状态,直到TEST有效.
说明: 本指令不影响标志位.
XCHG
数据交换指令 XCHG
格式: XCHG OPRD1,OPRD2 其中的OPRD1为目的操作数,OPRD2为源操作数
功能: 将两个操作数相互交换位置,该指令把源操作数OPRD2与目的操数OPRD1交换.
说明:
1. OPRD1及OPRD2可为通用寄存器或存储器,但是两个存储器之间是不能用XCHG指令实现的.
2. 段寄存器内容不能用XCHG指令来交换.
3. 若要实现两个存储器操作数DATA1及DATA2的交换,可用以下指令实现:
示例: PUSH DATA1
PUSH DATA2
POP DATA1
POP DATA2
4. 本指令不影响状态标志位.
XLAT
查表指令 XLAT
格式: XLAT TABLE其中TABLE为一待查表格的首地址.
功能: 把待查表格的一个字节内容送到AL累加器中.
说明:
1. 在执行该指令前,应将TABLE先送至BX寄存器中,然后将待查字节与在表格中距表首地址位移量送AL,即 (AL)<--((BX)+(AL)).
2. 本指令不影响状态标位,表格长度不超过256字节.
XOR
逻辑异或运算指令 XOR
格式: XOR OPRD1,OPRD2
功能: 实现两个操作数按位‘异或’运算,结果送至目的操作数中.
OPRD1<--OPRD1 XOR OPRD2
说明:
1. 其在OPRD1、OPRD2的含义与AND指令相同,对标志位的影响与与AND指令相同.
2. 相异为真,相同为假.
转自:http://blog.sina.com.cn/s/blog_4cf7f5cd0100n2wm.html,感谢这位细心的博主
二、特殊的指令-------------------------------------------------------
FILD
浮点加载整数命令 FILD
格式:fild fild dword ptr src
例子:fild dword ptr [eax+00000298]
说明:将src的整数转化为双精度的浮点数,然后送给cpu运算器FPU进行运算
AAA
未组合的十进制加法调整指令 AAA(ASCII Adgust for Addition)
格式: AAA
功能: 对两个组合的十进制数相加运算(存在AL中)的结果进行调整,产生一个未组合的十进制数放在AX中.
说明:
1. 组合的十进制数和未组合的十进制数:在计算中,十进制数可用四位二进制数编码,称为BCD码.
当一个节(8位)中存放一位BCD码,且放在字节的低4位, 高4位为时称为未组合的BCD码.
2. AAA的调整操作
若(AL) and 0FH>9 或 AF=1,则调整如下:
(AL)<--(AL)+6,(AH)<--(AH)+1,AF=1,CF<--AF,(AL)<--(AL) and 0FH
AAD
未组合十进制数除法调整指令 AAD(ASCII Adjust for Division)
格式: AAD
功能: 在除法指令前对AX中的两个未组合十进制数进行调整,以便能用DIV指令实现两个未组合的十进制数的除法运算,其结果为未组合的十进制数,商(在AL中)和余数(在AH中).
说明:
1. AAD指令是在执行除法DIV之前使用的,以便得到二进制结果存于AL中,然后除以OPRD,得到的商在AL中,余数在AH中.
2. 示例: MOV BL,5
MOV AX,0308H
AAD ;(AL)<--1EH+08H=26H,(AH)<--0
DIV BL ;商=07H-->(AL),余数=03H-->(AH).
AAM
未组合十进制数乘法调整指令 AAM(ASCII Adjust MULtiply)
格式: AAM
功能: 对两个未组合的十进制数相乘后存于AX中的结果进行调整,产生一个未组合的十进制数存在AL中.
说明:
1. 实际上是两个未组合的十进制数字节相乘,一个0~9的数与另一个0~9的数相乘其积最大为81.为了得到正确的结果,应进行如下调整:
乘积: (AH)<--(AL)/10
(AL)<--(AL)MOD10
2. 本指令应跟在MUL指令后使用,乘积的两位十进制结果,高位放在AH中,低位放在AL中.AH内容是MUL指令的结果被10除的商,即(AL)/10,而最后的AL内容是乘积被10整除的余数(即个位数).
AAS
未组合十进制减法调整指令 AAS(ASCII Adjust for Subtraction)
格式: AAS
功能: 对两个未组合十进制数相减后存于AL中的结果进行调整,调整后产生一个未组合的十进制数数且仍存于AL中.
说明:
1. 本指令影响标志位CF及AF.
2. 调整操作
若(AL) and 0FH > 9 或 AF=1
则(AL)<--(AL)-6,(AH)<--(AH)-1,CF<--AF,(AL)<--(AL) and 0FH,
否则(AL)<--(AL) and 0FH
ADC
带进位加法指令 ADC(Addition Carry)
格式: ADC OPRD1,OPRD2
功能: OPRD1<--OPRD1 + OPRD2 + CF
说明:
1. OPRD1为任一通用寄存器或存储器操作数,可以是任意一个通用寄存器,而且还可以是任意一个存储器操作数.
OPRD2为立即数,也可以是任意一个通用寄存器操作数.立即数只能用于源操作数.
2. OPRD1和OPRD2均为寄存器是允许的,一个为寄存器而另一个为存储器也是允许的,但不允许两个都是存储器操作数.
3. 加法指令运算的结果对CF、SF、OF、PF、ZF、AF都会有影响.以上标志也称为结果标志.
4. 该指令对标志位的影响同ADD指令.
ADD
加法指令 ADD(Addition)
格式: ADD OPRD1,OPRD2
功能: 两数相加
说明:
1. OPRD1为任一通用寄存器或存储器操作数,可以是任意一个通用寄存器,而且还可以是任意一个存储器操作数.
OPRD2为立即数,也可以是任意一个通用寄存器操作数.立即数只能用于源操作数.
2. OPRD1和OPRD2均为寄存器是允许的,一个为寄存器而另一个为存储器也是允许的, 但不允许两个都是存储器操作数.
3. 加法指令运算的结果对CF、SF、OF、PF、ZF、AF都会有影响.以上标志也称为结果标志.加法指令适用于无符号数或有符号数的加法运算.
AND
逻辑与运算指令 AND
格式: AND OPRD1,OPRD2
功能: 对两个操作数实现按位逻辑与运算,结果送至目的操作数.本指令可以进行字节或字的‘与’运算,
OPRD1<--OPRD1 and OPRD2.
说明:
1. 目的操作数OPRD1为任一通用寄存器或存储器操作数.源操作数OPRD2为立即数,任一通用寄存器或存储器操作数.
2. 示例: AND AL,0FH ;(AL)<--(AL) AND 0FH
AND AX,BX ;(AX)<--(AX) AND (BX)
AND DX,BUFFER[SI+BX]
AND BETA[BX],00FFH
注意: 两数相与,有一个数假则值为假
CALL
过程调用指令 CALL
格式: CALL OPRD
功能: 过程调用指令
说明:
1. 其中OPRD为过程的目的地址.
2. 过程调用可分为段内调用和段间调用两种.寻址方式也可以分为直接寻址和间接寻址两种.
3. 本指令不影响标志位.
CBW
字节扩展指令 CBW(Convert Byte to Word)
格式: CBW
功能: 将字节扩展为字,即把AL寄存器的符号位扩展到AH中.
说明:
1. 两个字节相除时,先使用本指令形成一个双字节长的被除数.
2. 本指令不影响标志位.
3. 示例: MOV AL,25
CBW
IDIV BYTE PTR DATA1
CLC
处理器控制指令-标志位操作指令
格式:
CLC ;置CF=0
STC ;置CF=1
CMC ;置CF=(Not CF)进位标志求反
CLD ;置DF=0
STD ;置DF=1
CLI ;置IF=0,CPU禁止响应外部中断
STI ;置IF=1,使CPU允许向应外部中断
功能: 完成对标志位的置位、复位等操作.
说明: 例如串操作中的程序,经常用CLD指令清方向标志使DF=0,在串操作指令执行时,按增量的方式修改吕指针.
CLD
处理器控制指令-标志位操作指令
格式:
CLC ;置CF=0
STC ;置CF=1
CMC ;置CF=(Not CF)进位标志求反
CLD ;置DF=0
STD ;置DF=1
CLI ;置IF=0,CPU禁止响应外部中断
STI ;置IF=1,使CPU允许向应外部中断
功能: 完成对标志位的置位、复位等操作.
说明: 例如串操作中的程序,经常用CLD指令清方向标志使DF=0,在串操作指令执行时,按增量的方式修改吕指针.
CLI
处理器控制指令-标志位操作指令
格式:
CLC ;置CF=0
STC ;置CF=1
CMC ;置CF=(Not CF)进位标志求反
CLD ;置DF=0
STD ;置DF=1
CLI ;置IF=0,CPU禁止响应外部中断
STI ;置IF=1,使CPU允许向应外部中断
功能: 完成对标志位的置位、复位等操作.
说明: 例如串操作中的程序,经常用CLD指令清方向标志使DF=0,在串操作指令执行时,按增量的方式修改吕指针.
CMC
处理器控制指令-标志位操作指令
格式:
CLC ;置CF=0
STC ;置CF=1
CMC ;置CF=(Not CF)进位标志求反
CLD ;置DF=0
STD ;置DF=1
CLI ;置IF=0,CPU禁止响应外部中断
STI ;置IF=1,使CPU允许向应外部中断
功能: 完成对标志位的置位、复位等操作.
说明: 例如串操作中的程序,经常用CLD指令清方向标志使DF=0,在串操作指令执行时,按增量的方式修改吕指针.
CMP
比效指令 CMP(CoMPare)
格式: CMP OPRD1,OPRD2
功能: 对两数进行相减,进行比较.
说明:
1. OPRD1为任意通用寄存器或存储器操作数.
OPRD2为任意通用寄存器或存储器操作数,立即数也可用作源操作数OPRD2.
2. 对标志位的影响同SUB指令,完成的操作与SUB指令类似,唯一的区别是不将OPRD1-OPRD2的结果送回OPRD1,而只是比较.
3. 在8088/8086指令系统中,专门提供了一组根据带符号数比较大小后,实现条件转移的指令.
CMPS
字符串比较指令
格式: CMPS OPRD1,OPRD2
CMPSB
CMPSW
功能: 由SI寻址的源串中数据与由DI寻址的目的串中数据进行比较,比较结果送标志位,而不改变操作数本身.
同时SI,DI将自动调整.
说明:
1. 其中OPRD2为源串符号地址,OPRD1为目的串符号地址.
2. 本指令影响标志位AF、CF、OF、SF、PF、ZF.本指令可用来检查二个字符串是否相同,可以使用循环控制方法对整串进行比较.
3. 与MOVS相似,CMPS指令也可以不使用操作数,此时可用指令CMPSB或CMPSW分别表示字节串比较或字串比较.
CMPSB
字符串比较指令
格式: CMPS OPRD1,OPRD2
CMPSB
CMPSW
功能: 由SI寻址的源串中数据与由DI寻址的目的串中数据进行比较,比较结果送标志位,而不改变操作数本身.
同时SI,DI将自动调整.
说明:
1. 其中OPRD2为源串符号地址,OPRD1为目的串符号地址.
2. 本指令影响标志位AF、CF、OF、SF、PF、ZF.本指令可用来检查二个字符串是否相同,可以使用循环控制方法对整串进行比较.
3. 与MOVS相似,CMPS指令也可以不使用操作数,此时可用指令CMPSB或CMPSW分别表示字节串比较或字串比较.
CMPSW
字符串比较指令
格式: CMPS OPRD1,OPRD2
CMPSB
CMPSW
功能: 由SI寻址的源串中数据与由DI寻址的目的串中数据进行比较,比较结果送标志位,而不改变操作数本身.
同时SI,DI将自动调整.
说明:
1. 其中OPRD2为源串符号地址,OPRD1为目的串符号地址.
2. 本指令影响标志位AF、CF、OF、SF、PF、ZF.本指令可用来检查二个字符串是否相同,可以使用循环控制方法对整串进行比较.
3. 与MOVS相似,CMPS指令也可以不使用操作数,此时可用指令CMPSB或CMPSW分别表示字节串比较或字串比较.
CWD
字扩展指令 CWD(Convert Word to Double Word)
格式: CWD
功能: 将字扩展为双字长,即把AX寄存器的符号位扩展到DX中.
说明:
1. 两个字或字节相除时,先用本指令形成一个双字长的的被除数.
2. 本指令不影响标志位.
3. 示例: 在B1、B2、B3字节类型变量中,分别存有8们带符号数a、b、c,实现(a*b+c)/a运算。
DAA
组合的十进制加法调整指令 DAA(Decimal Adjust for Addition)
格式: DAA
功能: 对AL中的两个组合进制数相加的结果进行调整,调整结果仍放在AL中,进位标志放在CF中.
说明:
1. 调整操作如下
(1) 若(AL) and 0FH>9 或 AF=1,则(AL)<--(AL)+6,AF<--1,对低四位的调整.
(2) 若(AL) and 0F0H>90H 或 CF=1,则(AL)<--(AL)+60H,CF<--1.
2. 示例: (AL)=18H,(BL)=06H
ADD AL,BL ; (AL)<--(AL)+(BL) ; (AL)=1EH
DAA ; (AL)
DAS
组合十进制减法调整指令 DAS(Decimal Adjust for Subtraction)
格式: DAS
功能: 对两个组合十进制数相减后存于AL中的结果进行调整,调整后产生一个组合的十进制数且仍存于AL中.
说明:
调整操作
若(AL) and 0FH > 9 或 AF=1,则(AL)<--(AL)-6,AF=1
若(AL) and 0F0H > 90H 或 CF=1,则(AL)<--(AL)-60,CF=1
DEC
减一指令 DEC(Decrement by 1)
格式: DEC OPRD
功能: OPRD<--OPRD-1
说明:
1. OPRD 为寄存器或存储器操作数.
2. 这条指令执行结果影响AF、OF、PF、SF、ZF标志位,但不影响CF标志位.
3. 示例 DEC AX
DEC CL
DEC WORD PTR[DI]
DEC ALFA[DI+BX]
DIV
无符号数除法指令 DIV(DIVision)
格式: DIV OPRD
功能: 实现两个无符号二进制数除法运算.
说明:
1. 其中OPRD为任一个通用寄存器或存储器操作数.
2. 字节相除,被除数在AX中;字相除,被除数在DX,AX中,除数在OPRD中.
字节除法: (AL)<--(AX)/OPRD,(AH)<--(AX)MOD OPRD
字除法: (AX)<--(DX)(AX)/OPRD,(DX)<--(DX)(AX) MOD OPRD
ESC
处理器交权指令 ESC
格式: ESC EXTOPRD,OPRD
功能: 使用本指令可以实现协处理器出放在ESC指令代码中的6位常数,该常数指明协处理器要完成的功能.
当源操作数为存储器变量时,则取出该存储器操作数传送给协处理器.
说明:
1. 其中EXTOPRD为外部操作码,OPRD为源操作数.
2. 本指不影响标志位.
HLT
处理器暂停指令 HLT
格式: HLT
功能: 使处理器处于暂时停机状态.
说明:
1. 本指令不影响标志位.
2. 由执行HLT引起的暂停,只有RESET(复位)、NMI(非屏蔽中断请求)、INTR(可屏蔽的外部中断请求)信号可以使
其退出暂停状态.它可用于等待中断的到来或多机系统的同步操作.
IDIV
带符号数除法指定 IDIV(Interger DIVision)
格式: IDIV OPRD
功能: 这实现两个带符号数的二进制除法运算.
说明:
1. 其中OPRD为任一通用寄存器或存储器操作数.
2. 理由与IMUL相同,只有IDIV指令,才能得到符号数相除的正确结果.
3. 当被除数为8位,在进行字节除法前,应把AL的符号位扩充至AH中.在16位除法时,若被除数为16位,则应将AX中的符号位扩到DX中.
IMUL
带符号数乘法指令 IMUL(Integer MULtiply)
格式: IMUL OPRD
功能: 完成两个带符号数的相乘
说明:
1. 其中OPRD为任一通用寄存器或存储器操作数.
2. MUL指令对带符号相乘时,不能得到正确的结果.
例如: (AL)=255
(CL)=255
MUL CL
(AX)=65025
注意: 这对无符号数讲,结果是正确的,但对带符号数讲,相当于(-1)*(-1)结果应为+1,而65025对应的带符号数为-511,显然是不正确的.
IN
输入指令 IN
格式: IN AL,n ;(AL)<--(n)
IN AX,n ;(AX)<--(n+1),(n)
IN AL,DX ;(AL)<--[(DX)]
IN AX,DX ;(AX)<--[(DX)+1],[(DX)]
功能: 输入指令
说明:
1. 其中n为8位的端口地址,当字节输入时,将端口地址n+1的内容送至AH中,端口地址n的内容送AL中.
2. 端口地址也可以是16位的,但必须将16位的端口地址送入DX中.当字节寻址时,由DX内容作端口地址的内容送至AL中;
当输入数据字时,[(DX)+1]送AH,[(DX)]送AL中,用符号:(AX)<--[(DX)+1],[(DX)]表示.
INC
加1指令 INC(INCrement by 1)
格式: INC OPRD
功能: OPRD<--OPRD+1
说明:
1. OPRD 为寄存器或存储器操作数.
2. 这条指令执行结果影响AF、OF、PF、SF、ZF标志位,但不影响CF标志位.
3. 示例:
INC SI;(SI)<--(SI)+1
INC WORD PTR[BX]
INC BYTE PTR[BX+DI]
INC CL;(CL)<--(CL)+1
注意: 上述第二,三两条指令,是对存储字及存储字节的内容加1以替代原来的内容.
INT
软中断指令 INT
格式: INT n 其中n为软中断的类型号.
功能: 本指令将产生一个软中断,把控制转向一个类型号为n的软中断,该中断处理程序入口地址在中断向量表的n*4地址
处的二个存储器字(4个单元)中.
说明: 操作过程与INTO指令雷同,只需将10H改为n*4即可.所以,本指令也将影响标志位IF及TF.
INTO
溢出中断指令 INTO(INTerrupt if Overflow)
格式: INTO
功能: 本指令检测OF标志位,当OF=1时,说明已发生溢出,立即产生一个中断类型4的中断,当OF=0时,本指令不起作用.
说明:
1. 本指令影响标志位IF及TF.
2. 本指令可用于溢出处理,当OF=1时,产生一个类型4的软中断.在中断处理程序中完成溢出的处理操作.
IRET
中断返回指令 IRET
格式: IRET
功能: 用于中断处理程序中,从中断程序的断点处返回,继续执行原程序.
说明:
1. 本指令将影响所有标志位.
2. 无论是软中断,还是硬中断,本指令均可使其返回到中断程序的断点处继续执行原程序.
JA
条件转移指令JA/JNBE
格式: JA/JNBE标号
功能: 为高于/不低于等于的转移指令
说明:
1. 例如两个符号数a,b比较时,a>b(即CF=0,ZF=0)时转移.因为单一标志位CF=0,只表示a>=b.
2. JA/JNBE是同一条指令的两种不同的助记符.
3. 该指令用于无符号数进行条件转移
JAE
条件转移指令JAE/JNB
格式: JAE/JNB 标号
功能: 为高于等于/不低于的转移指令
说明:
1. JAE/JNB是同一条指令的两种不同的助记符.
2. 该指令用于无符号数进行条件转移.
JB
条件转移指令JB/JNAE
格式: JB/JNAE 标号
功能: 低于/不高于等于时转移
说明: 该指令用于无符号数的条件转移
JBE
条件转移指令JBE/JNA
格式: JBE/JNA 标号
功能: 低于等于/不高于时转移
说明: 该指令用于无符号数的条件转移
JC
条件转移指令 JC
格式: JC 标号
功能: CF=1,转至标号处执行
说明: JC为根据标志位CF进行转移的指令
JE
条件转移指令JE/JZ
格式: JE/JZ标号
功能: ZF=1,转至标号处执
说明:
1. 指令JE与JZ等价,它们是根据标志位ZF进行转移的指令
2. JE,JZ均为一条指令的两种助记符表示方法
JG
条件转移指令JG/JNLE
格式: JG/JNLE 标号
功能: 大于/不小于等于时转移
说明: 用于带符号数的条件转移指令
JGE
条件转移指令JGE/JNL
格式: JGE/JNL标号
功能: 大于等于/不小于时转移
说明: 用于带符号数的条件转移指令
JL
条件转移指令JL/JNGE
格式: JL/JNGE标号
功能: 小于/不大于等于时转移
说明: 用于带符号数的条件转移指令
JLE
条件转移指令JLE/JNG
格式: JLE/JNG 标号
功能: 小于等于/不大于时转移
说明: 用于带符号数的条件转移指令
JMP
无条件转移指令JMP
格式: JMP OPRD
功能: JMP指令将无条件地控制程序转移到目的地址去执行.当目的地址仍在同一个代码段内,称为段内转移;当目标地址不在同一个代码段内,则称为段间转移.这两种情况都将产生不同的指令代码,以便能正确地生成目的地址,在段内转移时,指令只要能提供目的地址的段 内偏移量即够了;而在段间转移时,指令应能提供目的地址的段地址及段内偏移地址值.
说明:
1. 其中OPRD为转移的目的地址.程序转移到目的地址所指向的指令继续往下执行.
2. 本组指令对标志位无影响.
3. <1> 段内直接转移指令: JMP NEAR 标号
<2> 段内间接转移指令: JMP OPRD
<3> 段间直接转移指令: JMP FAR 标号
<4> 段间间接转移指令:JMP OPRD其中的OPRD为存储器双字操作数.段间间接转移只能通过存储器操作数来实现.
JNA
条件转移指令JBE/JNA
格式: JBE/JNA 标号
功能: 低于等于/不高于时转移
说明: 该指令用于无符号数的条件转移
JNAE
条件转移指令JB/JNAE
格式: JB/JNAE 标号
功能: 低于/不高于等于时转移
说明: 该指令用于无符号数的条件转移
JNB
条件转移指令JAE/JNB
格式: JAE/JNB 标号
功能: 为高于等于/不低于的转移指令
说明:
1. JAE/JNB是同一条指令的两种不同的助记符.
2. 该指令用于无符号数进行条件转移.
JNBE
条件转移指令JA/JNBE
格式: JA/JNBE标号
功能: 为高于/不低于等于的转移指令
说明:
1. 例如两个符号数a,b比较时,a>b(即CF=0,ZF=0)时转移.因为单一标志位CF=0,只表示a>=b.
2. JA/JNBE是同一条指令的两种不同的助记符.
3. 该指令用于无符号数进行条件转移
JNC
条件转移指令JNC
格式: JNC标号
功能: CF=0,转至标号处执行
说明: JNC为根据标志位CF进行转移的指令
JNE
条件转移指令JNE/JNZ
格式: JNE/JNZ 标号
功能: ZF=0,转至标号处执行
说明:
1. 指令JNE与JNZ等价,它们是根据标志位ZF进行转移的指令
2. JNE,JNZ均为一条指令的两种助记符表示方法
JNG
条件转移指令JLE/JNG
格式: JLE/JNG 标号
功能: 小于等于/不大于时转移
说明: 用于带符号数的条件转移指令
JNGE
条件转移指令JL/JNGE
格式: JL/JNGE标号
功能: 小于/不大于等于时转移
说明: 用于带符号数的条件转移指令
JNL
条件转移指令JGE/JNL
格式: JGE/JNL标号
功能: 大于等于/不小于时转移
说明: 用于带符号数的条件转移指令
JNLE
条件转移指令JG/JNLE
格式: JG/JNLE 标号
功能: 大于/不小于等于时转移
说明: 用于带符号数的条件转移指令
JNO
条件转移指令JNO
格式: JNO 标号
功能: OF=0,转至标号处执行
说明: JNO是根椐溢出标志位OF进行转移的指令
JNP
条件转移指令JNP/JPO
格式: JNP/JPO 标号
功能: PF=0,转至标号处执行
说明:
1. 指令JNP与JPO,它们是根据奇偶标志位PF进行转移的指令
2. JNP,JPO均为一条指令的两种助记符表示方法
JNS
条件转移指令JNS
格式: JNS 标号
功能: SF=0,转至标号处执行
说明: JNS是根据符号标志位SF进行转移的指令
JNZ
条件转移指令JNE/JNZ
格式: JNE/JNZ 标号
功能: ZF=0,转至标号处执行
说明:
1. 指令JNE与JNZ等价,它们是根据标志位ZF进行转移的指令
2. JNE,JNZ均为一条指令的两种助记符表示方法
JO
条件转移指令JO
格式: JO 标号
功能: OF=1,转至标号处执行
说明: JO是根椐溢出标志位OF进行转移的指令
JP
条件转移指令JP/JPE
格式: JP/JPE 标号
功能: PF=1,转至标号处执行
说明:
1. 指令JP与JPE,它们是根据奇偶标志位PF进行转移的指令
2. JP,JPE均为一条指令的两种助记符表示方法
JPE
条件转移指令JP/JPE
格式: JP/JPE 标号
功能: PF=1,转至标号处执行
说明:
1. 指令JP与JPE,它们是根据奇偶标志位PF进行转移的指令
2. JP,JPE均为一条指令的两种助记符表示方法
JPO
条件转移指令JNP/JPO
格式: JNP/JPO 标号
功能: PF=0,转至标号处执行
说明:
1. 指令JNP与JPO,它们是根据奇偶标志位PF进行转移的指令
2. JNP,JPO均为一条指令的两种助记符表示方法
JS
条件转移指令JS
格式: JS 标号
功能: SF=1,转至标号处执行
说明: JS是根据符号标志位SF进行转移的指令
JZ
条件转移指令JE/JZ
格式: JE/JZ标号
功能: ZF=1,转至标号处执
说明:
1. 指令JE与JZ等价,它们是根据标志位ZF进行转移的指令
2. JE,JZ均为一条指令的两种助记符表示方法
LAHF
标志传送指令 LAHF
格式: LAHF
功能: 取FLAG标志寄存器低8位至AH寄存器.(AH)<--(FLAG)7~0
说明: 该指令不影响FLAG的原来内容,AH只是复制了原FLAG的低8位内容.
LDS
从存储器取出32位地址的指令 LDS
格式: LDS OPRD1,OPRD2
功能: 从存储器取出32位地址的指令.
说明:
OPRD1 为任意一个16位的寄存器.
OPRD2 为32位的存储器地址.
示例: LDS SI,ABCD
LDS BX,FAST[SI]
LDS DI,[BX]
注意: 上面LDS DI,[BX]指令的功能是把BX所指的32位地址指针的段地址送入DS,偏移地址送入DI.
LEA
有效地址传送指令 LEA
格式: LEA OPRD1,OPRD2
功能: 将源操作数给出的有效地址传送到指定的的寄存器中.
说明:
1. OPRD1 为目的操作数,可为任意一个16位的通用寄存器.
OPRD2 为源操作数,可为变量名、标号或地址表达式.
示例: LEA BX,DATA1
LEA DX,BETA[BX+SI]
LEA BX BX,[BP],[DI]
2. 本指令对标志位无影响。
LES
从存储器取出32位地址的指令 LES
格式: LES OPRD1,OPRD2
功能: 从存储器取出32位地址的指令.
说明:
OPRD1 为任意一个16位的寄存器.
OPRD2 为32位的存储器地址.
示例: LES SI,ABCD
LES BX,FAST[SI]
LES DI,[BX]
注意: 上面LES DI,[BX]指令的功能是把BX所指的32位地址指针的段地址送入ES,偏移地址送入DI.
LOCK
封锁总线指令 LOCK
格式: LOCK
功能: 指令是一个前缀,可放在指令的前面,告诉CPU在执行该指令时,不允许其它设备对总线进行访问.
无可用信息!用户可自行添加!
LODS
取字符串元素指令 LODS
格式: LODS OPRD 其中OPRD为源字符串符号地址.
功能: 把SI寻址的源串的数据字节送AL或数据字送AX中去, 并根据DF的值修改地址指针SI进行自动调整.
说明:
1. 本指令不影响标志位.
2. 当不使用操作数时,可用LODS(字节串)或LODSW(字串)指令.
LOOP
循环控制指令LOOP
格式: LOOP 标号
功能: (CX)<--(CX)-1,(CX)<>0,则转移至标号处循环执行, 直至(CX)=0,继续执行后继指令.
说明:
1. 本指令是用CX寄存器作为计数器,来控制程序的循环.
2. 它属于段内SHORT短类型转移,目的地址必须距本指令在-128到+127个字节的范围内.
LOOPE
循环控制指令LOOPZ/LOOPE
格式: LOOPZ/LOOPE 标号
功能: (CX)<--(CX)-1,(CX)<>0 且ZF=1时,转至标号处循环
说明:
1. 本指令是用CX寄存器作为计数器,来控制程序的循环.
2. 它属于段内SHORT短类型转移,目的地址必须距本指令在-128到+127个字节的范围内.
3. 以上两种助记符等价.
LOOPNE
循环控制指令LOOPNZ/LOOPNE
格式: LOOPNZ/LOOPNE 标号
功能: (CX)<--(CX)-1,(CX)<>0 且ZF=0时,转至标号处循环
说明:
1. 本指令是用CX寄存器作为计数器,来控制程序的循环.
2. 它属于段内SHORT短类型转移,目的地址必须距本指令在-128到+127个字节的范围内.
3. 以上两种助记符等价.
LOOPNZ
循环控制指令LOOPNZ/LOOPNE
格式: LOOPNZ/LOOPNE 标号
功能: (CX)<--(CX)-1,(CX)<>0 且ZF=0时,转至标号处循环
说明:
1. 本指令是用CX寄存器作为计数器,来控制程序的循环.
2. 它属于段内SHORT短类型转移,目的地址必须距本指令在-128到+127个字节的范围内.
3. 以上两种助记符等价.
LOOPZ
循环控制指令LOOPZ/LOOPE
格式: LOOPZ/LOOPE 标号
功能: (CX)<--(CX)-1,(CX)<>0 且ZF=1时,转至标号处循环
说明:
1. 本指令是用CX寄存器作为计数器,来控制程序的循环.
2. 它属于段内SHORT短类型转移,目的地址必须距本指令在-128到+127个字节的范围内.
3. 以上两种助记符等价.
MOVE
数据传送指令 MOV
格式: MOV OPRD1,OPRD2
功能: 本指令将一个源操作数送到目的操作数中,即OPRD1<--OPRD2.
说明:
1. OPRD1 为目的操作数,可以是寄存器、存储器、累加器.
OPRD2 为源操作数,可以是寄存器、存储器、累加器和立即数.
2. MOV 指令以分为以下四种情况:
<1> 寄存器与寄存器之间的数据传送指令
<2> 立即数到通用寄存器数据传送指令
<3> 寄存器与存储器之间的数据传送指令
<4> 立即数到存储器的数据传送
3. 本指令不影响状态标志位
MOVS
字符串传送指令 MOVS
格式: MOVS OPRD1,OPRD2
MOVSB
MOVSW
功能: OPRD1<--OPRD2.
说明:
1. 其中OPRD2为源串符号地址,OPRD1为目的串符号地址.
2. 字节串操作: 若DF=0,则作加, 若DF=1,则作减.
3. 对字串操作时: 若DF=0,则作加,若DF=1,则作减,.
4. 在指令中不出现操作数时,字节串传送格式为MOVSB、字串传送格式为MOVSW.
5. 本指令不影响标志位.
MOVSB
字符串传送指令 MOVS
格式: MOVS OPRD1,OPRD2
MOVSB
MOVSW
功能: OPRD1<--OPRD2.
说明:
1. 其中OPRD2为源串符号地址,OPRD1为目的串符号地址.
2. 字节串操作: 若DF=0,则作加, 若DF=1,则作减.
3. 对字串操作时: 若DF=0,则作加,若DF=1,则作减,.
4. 在指令中不出现操作数时,字节串传送格式为MOVSB、字串传送格式为MOVSW.
5. 本指令不影响标志位.
MOVSW
字符串传送指令 MOVS
格式: MOVS OPRD1,OPRD2
MOVSB
MOVSW
功能: OPRD1<--OPRD2.
说明:
1. 其中OPRD2为源串符号地址,OPRD1为目的串符号地址.
2. 字节串操作: 若DF=0,则作加, 若DF=1,则作减.
3. 对字串操作时: 若DF=0,则作加,若DF=1,则作减,.
4. 在指令中不出现操作数时,字节串传送格式为MOVSB、字串传送格式为MOVSW.
5. 本指令不影响标志位.
MUL
无符号数乘法指令 MUL(MULtiply)
格式: MUL OPRD
功能: 乘法操作.
说明:
1. OPRD为通用寄存器或存储器操作数.
2. OPRD为源操作数,即作乘数.目的操作数是隐含的,即被乘数总是指定为累加器AX或AL的内容.
3. 16位乘法时,AX中为被乘数.8位乘法时,AL为被乘数.当16位乘法时,32位的乘积存于DX及AX中;8位乘法的16位乘积存于AX中.
4. 操作过程: 字节相乘:(AX)<--(AL)*OPRD,当结果的高位字节(AH)不等于0时,则CF=1、OF=1.
NEG
取补指令 NEG(NEGate)
格式: NEG OPRD
功能: 对操作数OPRD进行取补操作,然后将结果送回OPRD.取补操作也叫作求补操作,就是求一个数的相反数的补码.
说明:
1. OPRD为任意通用寄存器或存储器操作数.
2. 示例: (AL)=44H,取补后,(AL)=0BCH(-44H).
3. 本指令影响标志位CF、OF、SF、PF、ZF及AF.
NOP
空操作指令 NOP
格式: NOP
功能: 本指令不产生任何结果,仅消耗几个时钟周期的时间,接着执行后续指令,常用于程序的延时等.
说明: 本指令不影响标志位.
NOT
逻辑非运算指令 NOT
格式: NOT OPRD
功能: 完成对操作数按位求反运算(即0变1,1变0),结果关回原操作数.
说明:
1. 其中OPRD可为任一通用寄存器或存储器操作数.
2. 本指梳令可以进行字或字节‘非’运算.
3. 本指令不影响标志位.
OR
逻辑或指令 OR
格式: OR OPRD1,OPRD2
功能: OR指令完成对两个操作数按位的‘或’运算,结果送至目的操作数中,本指令可以进行字节或字的‘或’运算.
OPRD1<--OPRD1 OR OPRD2.
说明:
1. 其中OPRD1,OPRD2含义与AND指令相同,对标志位的影响也与AND指令相同.
2. 两数相或,有一个数为真则值为真.
OUT
输出指令 OUT
格式: OUT n,AL ;(n)<--(AL)
功能: 输出指令
说明:
1. OUT n,AX ;(n+1),(n)<--(AX)
OUT DX,AL ;[(DX)]<--(AL)
OUT DX,AX ;[(DX)+1],[(DX)]<--(AX)
2. 输入指令及输出指令对标志位都不影响.
POP
堆栈操作指令 PUSH和POP
格式: PUSH OPRD
POP OPRD
功能: 实现压入操作的指令是PUSH指令;实现弹出操作的指令是POP指令.
说明:
1. OPRD为16位(字)操作数,可以是寄存器或存储器操作数.
2. POP指令的操作过程是: POP OPRD:OPRD<--((SP)),(SP)<--(SP)+2
它与压入操作相反,是先弹出栈顶的数顶,然后再修改指针SP的内容.
3. 示例: POP AX
POP DS
POP DATA1 POP ALFA[BX][DI]
4. PUSH和POP指令对状态标志位没有影响.
POPF
标志传送指令 POPF
格式: POPF
功能: 本指令的功能与PUSHF相反,在子程序调用和中断服务程序中,往往用PUSHF指令保护FLAG的内容,用POPF指令将保护的FLAG内容恢复.
说明: 如果对堆栈中的原FLAG内容进行修改,如对TF等标志位进行修改,然后再弹回标志位寄存器FLAG.这是通过指令修改TF标志的唯一方法.
PUSH
堆栈操作指令 PUSH和POP
格式: PUSH OPRD
POP OPRD
功能: 实现压入操作的指令是PUSH指令;实现弹出操作的指令是POP指令.
说明:
1. OPRD为16位(字)操作数,可以是寄存器或存储器操作数.
2. PUSH的操作过程是: (SP)<--(SP)-2,((sp))<--OPRD 即先修改堆栈指针SP(压入时为自动减2),然后,将指定的操作数送入新的栈顶位置.
此处的((SP))<--OPRD,也可以理解为: [(SS)*16+(SP)]<--OPRD 或 [SS:SP]<--OPRD
PUSHF
标志传送指令 PUSHF
格式: PUSHF
功能: 本指令可以把标志寄存器的内容保存到堆栈中去
RCL
循环移位指令
格式: ROL OPRD1,COUNT ;不含进位标志位CF在循环中的左循环移位指令.
ROR OPRD1,COUNT ;不含进位示志位CF在循环中的右循环移位指令.
RCL OPRD1,COUNT ;带进位的左循环移位指令.
RCR OPRD1,COUNT ;带进位的右循环移位指令.
说明:
1. 本指令组只影响标志CF、OF.OF由移入CF的内容决定,OF取决于移位一次后符号位是否改变,如改变,则OF=1.
2. 由于是循环移位,所以对字节移位8次; 对字移位16次,就可恢复为原操作数.由于带CF的循环移位,可以将CF的内容移入,
所以可以利用它实现多字节的循环.
RCR
循环移位指令
格式: ROL OPRD1,COUNT ;不含进位标志位CF在循环中的左循环移位指令.
ROR OPRD1,COUNT ;不含进位示志位CF在循环中的右循环移位指令.
RCL OPRD1,COUNT ;带进位的左循环移位指令.
RCR OPRD1,COUNT ;带进位的右循环移位指令.
说明:
1. 本指令组只影响标志CF、OF.OF由移入CF的内容决定,OF取决于移位一次后符号位是否改变,如改变,则OF=1.
2. 由于是循环移位,所以对字节移位8次; 对字移位16次,就可恢复为原操作数.由于带CF的循环移位,可以将CF的内容移入,所以可以利用它实现多字节的循环.
注意: 以上程序中的指令SHR AL,CL如改为SAR AL,CL,虽然最高4位可移入低4位,但最高位不为0,故应加入一条指令AND AL,0FH.否则,若最高位不为0时,将得到错误结果.
REP
重复前缀的说明
格式: REP ;CX<>0 重复执行字符串指令
REPZ/REPE ;CX<>0 且ZF=1重复执行字符串指令
REPNZ/REPNE ;CX<>0 且ZF=0重复执行字符串指令
功能: 在串操作指令前加上重复前缀,可以对字符串进重复处理.由于加上重复前缀后,对应的指令代码是不同的,所以指令的功能便具有重复处理的功能,重复的次数存放在CX寄存器中.
说明:
1. REP与MOVS或STOS串操作指令相结合使用,完成一组字符的传送或建立一组相同数据的字符串.
2. REPZ/REPE常用与CMPS串操作指令结合使用, 可以完成两组字符串的比较.
3. REPZ/REPE常与SCAS指令结合使用,可以完成在一个字符串中搜索一个关键字.
4. REPNZ/REPNE与CMPS指令结合使用,表示当串未结束(CX=1)且当对应串元素不相同(ZF=0)时,继续重复执行串比较指令.
REPE
重复前缀的说明
格式: REP ;CX<>0 重复执行字符串指令
REPZ/REPE ;CX<>0 且ZF=1重复执行字符串指令
REPNZ/REPNE ;CX<>0 且ZF=0重复执行字符串指令
功能: 在串操作指令前加上重复前缀,可以对字符串进重复处理.由于加上重复前缀后,对应的指令代码是不同的,所以指令的功能便具有重复处理的功能,重复的次数存放在CX寄存器中.
说明:
1. REPZ/REPE常用与CMPS串操作指令结合使用, 可以完成两组字符串的比较.
2. REPZ/REPE常与SCAS指令结合使用,可以完成在一个字符串中搜索一个关键字.
3. REPNZ/REPNE与CMPS指令结合使用,表示当串未结束(CX=1)且当对应串元素不相同(ZF=0)时,继续重复执行串比较指令.
4. REPNZ/REPNE与SCAS指令结合使用,表示串未结束(CX=1)且当关键字与串元素不相同(ZF=0)时,继续重复执行串搜索指令.
REPNE
重复前缀的说明
格式: REP ;CX<>0 重复执行字符串指令
REPZ/REPE ;CX<>0 且ZF=1重复执行字符串指令
REPNZ/REPNE ;CX<>0 且ZF=0重复执行字符串指令
说明:
1. REPZ/REPE常用与CMPS串操作指令结合使用, 可以完成两组字符串的比较.
2. REPZ/REPE常与SCAS指令结合使用,可以完成在一个字符串中搜索一个关键字.
3. REPNZ/REPNE与CMPS指令结合使用,表示当串未结束(CX=1)且当对应串元素不相同(ZF=0)时,继续重复执行串比较指令.
4. REPNZ/REPNE与SCAS指令结合使用,表示串未结束(CX=1)且当关键字与串元素不相同(ZF=0)时,继续重复执行串搜索指令.
REPNZ
重复前缀的说明
格式: REP ;CX<>0 重复执行字符串指令
REPZ/REPE ;CX<>0 且ZF=1重复执行字符串指令
REPNZ/REPNE ;CX<>0 且ZF=0重复执行字符串指令
说明:
1. REPZ/REPE常用与CMPS串操作指令结合使用, 可以完成两组字符串的比较.
2. REPZ/REPE常与SCAS指令结合使用,可以完成在一个字符串中搜索一个关键字.
3. REPNZ/REPNE与CMPS指令结合使用,表示当串未结束(CX=1)且当对应串元素不相同(ZF=0)时,继续重复执行串比较指令.
4. REPNZ/REPNE与SCAS指令结合使用,表示串未结束(CX=1)且当关键字与串元素不相同(ZF=0)时,继续重复执行串搜索指令.
REPZ
重复前缀的说明
格式: REP ;CX<>0 重复执行字符串指令
REPZ/REPE ;CX<>0 且ZF=1重复执行字符串指令
REPNZ/REPNE ;CX<>0 且ZF=0重复执行字符串指令
功能: 在串操作指令前加上重复前缀,可以对字符串进重复处理.由于加上重复前缀后,对应的指令代码是不同的,所以指令的功能便具有重复处理的功能,重复的次数存放在CX寄存器中.
说明:
1. REPZ/REPE常用与CMPS串操作指令结合使用, 可以完成两组字符串的比较.
2. REPZ/REPE常与SCAS指令结合使用,可以完成在一个字符串中搜索一个关键字.
3. REPNZ/REPNE与CMPS指令结合使用,表示当串未结束(CX=1)且当对应串元素不相同(ZF=0)时,继续重复执行串比较指令.
4. REPNZ/REPNE与SCAS指令结合使用,表示串未结束(CX=1)且当关键字与串元素不相同(ZF=0)时,继续重复执行串搜索指令.
RET
返回指令 RET
格式: RET
功能: 当调用的过程结束后实现从过程返回至原调用程序的下一条指令,本指令不影响标志位.
说明:
由于在过程定义时,已指明其近(NEAR)或远(FAR)的属性,所以RET指令根据段内调用与段间调用,执行不同的操作
对段内调用: 返回时,由堆栈弹出一个字的返回地址的段内偏移量至IP.
对段外调用: 返回时,由堆栈弹出的第一个字为返回地址的段内偏移量,将其送入IP中,由堆栈弹出第二个字为返回地址的段基址,将其送入CS中.
ROL
循环移位指令
格式: ROL OPRD1,COUNT ;不含进位标志位CF在循环中的左循环移位指令.
ROR OPRD1,COUNT ;不含进位示志位CF在循环中的右循环移位指令.
RCL OPRD1,COUNT ;带进位的左循环移位指令.
RCR OPRD1,COUNT ;带进位的右循环移位指令.
说明:
1. 本指令组只影响标志CF、OF.OF由移入CF的内容决定,OF取决于移位一次后符号位是否改变,如改变,则OF=1.
2. 由于是循环移位,所以对字节移位8次; 对字移位16次,就可恢复为原操作数.由于带CF的循环移位,可以将CF的内容移入,
所以可以利用它实现多字节的循环.
ROR
循环移位指令
格式:
ROL OPRD1,COUNT ;不含进位标志位CF在循环中的左循环移位指令.
ROR OPRD1,COUNT ;不含进位示志位CF在循环中的右循环移位指令.
RCL OPRD1,COUNT ;带进位的左循环移位指令.
RCR OPRD1,COUNT ;带进位的右循环移位指令.
说明:
1. 本指令组只影响标志CF、OF.OF由移入CF的内容决定,OF取决于移位一次后符号位是否改变,如改变,则OF=1.
2. 由于循环移位,所以对字节移位8次; 对字移位16次,可恢复为原操作数.
SAHF
标志传送指令 SAHF
格式: SAHF
功能: 将AH存至FLAG低8位
说明: 本指令将用AH的内容改写FLAG标志寄存器中的SF、ZF、AF、PF、和CF标志,从而改变原来的标志位.
SAL
算术左移指令 SAL(Shift Arithmetic Left)
格式: SAL OPRD1,COUNT
功能: 其中OPRD1,COUNT与指令SHL相同.本指令与SHL的功能也完全相同,这是因为逻辑左移指令与算术左移指令所要完成的操作是一样的.
说明:
1. 其中OPRD1为目的操作数,可以是通用寄存器或存储器操作数.
2. COUNT代表移位的次数(或位数).移位一次,COUNT=1;移位多于1次时,COUNT=(CL),(CL)中为移位的次数.
SAR
算术右移指令 SAR
格式: SAR OPRD1,COUNT
功能: 本指令通常用于对带符号数减半的运算中,因而在每次右移时,保持最高位(符号位)不变,最低位右移至CF中.
说明:
1. 其中OPRD1为目的操作数,可以是通用寄存器或存储器操作数.
2. COUNT代表移位的次数(或位数).移位一次,COUNT=1;移位多于1次时,COUNT=(CL),(CL)中为移位的次数.
SBB
带借位减去指令 SBB(SuBtraction with Borrow)
格式: SBB OPRD1,OPRD2
功能: 是进行两个操作数的相减再减去CF进位标志位,即从OPRD1<--OPRD1-OPRD2-CF,其结果放在OPDR1中.
说明:
示例 SBB DX,CX
SBB AX,DATA1
SBB BX,2000H
SBB ALFA[BX+SI],SI
SBB BETAP[DI,030AH
SCAS
字符串搜索指令 SCAS
格式: SCAS OPRD
SCASB
SCASW
功能: 把AL(字节串)或AX(字串)的内容与由DI寄存器寻址的目的串中的数据相减,结果置标志位,但不改变任一操作数本身.
地址指针DI自动调整.
说明:
1. 其中OPRD为目的串符号地址.
2. 本指令影响标志AF、CF、OF、PF、SF、ZF.该指令可查找字符串中的一个关键字,只需在本指令执行前,
把关键字放在AL(字节)或AX(字串 )中,用重复前缀可在整串中查找.
指令中不使用操作数时,可用指令格式SCASB,SCASW,分别表示字节串或字串搜索指令.
SCASB
字符串搜索指令 SCAS
格式: SCAS OPRD
SCASB
SCASW
功能: 把AL(字节串)或AX(字串)的内容与由DI寄存器寻址的目的串中的数据相减,结果置标志位,但不改变任一操作数本身.
地址指针DI自动调整.
说明:
1. 其中OPRD为目的串符号地址.
2. 本指令影响标志AF、CF、OF、PF、SF、ZF.该指令可查找字符串中的一个关键字,只需在本指令执行前,
把关键字放在AL(字节)或AX(字串 )中,用重复前缀可在整串中查找.
指令中不使用操作数时,可用指令格式SCASB,SCASW,分别表示字节串或字串搜索指令.
SCASW
字符串搜索指令 SCAS
格式: SCAS OPRD
SCASB
SCASW
功能: 把AL(字节串)或AX(字串)的内容与由DI寄存器寻址的目的串中的数据相减,结果置标志位,但不改变任一操作数本身.
地址指针DI自动调整.
说明:
1. 其中OPRD为目的串符号地址.
2. 本指令影响标志AF、CF、OF、PF、SF、ZF.该指令可查找字符串中的一个关键字,只需在本指令执行前,
把关键字放在AL(字节)或AX(字串 )中,用重复前缀可在整串中查找.
指令中不使用操作数时,可用指令格式SCASB,SCASW,分别表示字节串或字串搜索指令.
SHL
逻辑左移指令 SHL(Shift logical left)
格式: SHL OPRD1,COUNT
功能: 对给定的目的操作数左移COUNT次,每次移位时最高位移入标志位CF中,最低位补零.
说明:
1. 其中OPRD1为目的操作数,可以是通用寄存器或存储器操作数.
2. COUNT代表移位的次数(或位数).移位一次,COUNT=1;移位多于1次时,COUNT=(CL),(CL)中为移位的次数.
3. 例如: SHL AL,1
SHL CX,1
SHL ALFA[DI] 或者:
MOV CL,3
SHL DX,CL
SHL ALFA[DI],CL
SHR
逻辑右移指令 SHR
格式: SHR OPRD1,COUNT
功能: 本指令实现由COUNT决定次数的逻辑右移操作,每次移位时,最高位补0,最低位移至标志位CF中.
说明:
1. 其中OPRD1为目的操作数,可以是通用寄存器或存储器操作数.
2. COUNT代表移位的次数(或位数).移位一次,COUNT=1;移位多于1次时,COUNT=(CL),(CL)中为移位的次数.
3. 影响标志位OF,PF,SF,ZF,CF.
STC
处理器控制指令-标志位操作指令
格式:
CLC ;置CF=0
STC ;置CF=1
CMC ;置CF=(Not CF)进位标志求反
CLD ;置DF=0
STD ;置DF=1
CLI ;置IF=0,CPU禁止响应外部中断
STI ;置IF=1,使CPU允许向应外部中断
功能: 完成对标志位的置位、复位等操作.
说明: 例如串操作中的程序,经常用CLD指令清方向标志使DF=0,在串操作指令执行时,按增量的方式修改吕指针.
STD
处理器控制指令-标志位操作指令
格式:
CLC ;置CF=0
STC ;置CF=1
CMC ;置CF=(Not CF)进位标志求反
CLD ;置DF=0
STD ;置DF=1
CLI ;置IF=0,CPU禁止响应外部中断
STI ;置IF=1,使CPU允许向应外部中断
功能: 完成对标志位的置位、复位等操作.
说明: 例如串操作中的程序,经常用CLD指令清方向标志使DF=0,在串操作指令执行时,按增量的方式修改吕指针.
STI
处理器控制指令-标志位操作指令
格式:
CLC ;置CF=0
STC ;置CF=1
CMC ;置CF=(Not CF)进位标志求反
CLD ;置DF=0
STD ;置DF=1
CLI ;置IF=0,CPU禁止响应外部中断
STI ;置IF=1,使CPU允许向应外部中断
功能: 完成对标志位的置位、复位等操作.
说明: 例如串操作中的程序,经常用CLD指令清方向标志使DF=0,在串操作指令执行时,按增量的方式修改吕指针.
STOS
字符串存储指令 STOS
格式: STOS OPRD
功能: 把AL(字节)或AX(字)中的数据存储到DI为目的串地址指针所寻址的存储器单元中去.指针DI将根据DF的值进行自动调整.
说明:
1. 其中OPRD为目的串符号地址.
2. 本指令不影响标志位.当不使用操作数时,可用STOSB或STOSW分别表示字节串或字串的操作.
SUB
减法指令SUB(SUBtract)
格式: SUB OPRD1,OPRD2
功能: 两个操作数的相减,即从OPRD1中减去OPRD2,其结果放在OPDR1中.
说明:
示例 SUB DX,CX
SUB [BX+25],AX
SUB DI,ALFA[SI]
SUB CL,20
SUB DATA1[DI][BX],20A5H
TEST
测试指令 TEST
格式: TEST OPRD1,OPRD2
功能: 其中OPRD1、OPRD2的含义同AND指令一样,也是对两个操作数进行按位的'与'运算,唯一不同之处是不将'与'的结
果送目的操作数,即本指令对两个操作数 的内容均不进行修改,仅是在逻辑与操作后,对标志位重新置位.
说明: TEST与AND指令的关系,有点类似于CMP与SUB指令之间的关系.
WAIT
处理器等待指令 WAIT
格式: WAIT
功能: 本指令将使处理器检测TEST端脚,当TEST有效时,则退出等待状态执行下条指令,否则处理器处于等待状态,直到TEST有效.
说明: 本指令不影响标志位.
XCHG
数据交换指令 XCHG
格式: XCHG OPRD1,OPRD2 其中的OPRD1为目的操作数,OPRD2为源操作数
功能: 将两个操作数相互交换位置,该指令把源操作数OPRD2与目的操数OPRD1交换.
说明:
1. OPRD1及OPRD2可为通用寄存器或存储器,但是两个存储器之间是不能用XCHG指令实现的.
2. 段寄存器内容不能用XCHG指令来交换.
3. 若要实现两个存储器操作数DATA1及DATA2的交换,可用以下指令实现:
示例: PUSH DATA1
PUSH DATA2
POP DATA1
POP DATA2
4. 本指令不影响状态标志位.
XLAT
查表指令 XLAT
格式: XLAT TABLE其中TABLE为一待查表格的首地址.
功能: 把待查表格的一个字节内容送到AL累加器中.
说明:
1. 在执行该指令前,应将TABLE先送至BX寄存器中,然后将待查字节与在表格中距表首地址位移量送AL,即 (AL)<--((BX)+(AL)).
2. 本指令不影响状态标位,表格长度不超过256字节.
XOR
逻辑异或运算指令 XOR
格式: XOR OPRD1,OPRD2
功能: 实现两个操作数按位‘异或’运算,结果送至目的操作数中.
OPRD1<--OPRD1 XOR OPRD2
说明:
1. 其在OPRD1、OPRD2的含义与AND指令相同,对标志位的影响与与AND指令相同.
2. 相异为真,相同为假.
转自:http://blog.sina.com.cn/s/blog_4cf7f5cd0100n2wm.html,感谢这位细心的博主
二、特殊的指令-------------------------------------------------------
FILD
浮点加载整数命令 FILD
格式:fild fild dword ptr src
例子:fild dword ptr [eax+00000298]
说明:将src的整数转化为双精度的浮点数,然后送给cpu运算器FPU进行运算
发表评论
-
汇编中的协处理器及命令大全
2011-04-26 13:34 3621协处理器共有68条不同的指令,汇编程序在遇到协处理器指令 ... -
汇编递归中的ret跳到了哪?
2011-04-04 16:32 4540汇编递归调用的时候,call的每一句,实际上都将其下一句 ... -
汇编除法指令div需要注意的
2011-04-02 18:04 3862div是除法指令,使用div做除法的时候应注意以下问题: 1 ... -
汇编寄存器的使用,SI,DI的使用
2011-04-01 13:23 33228一、汇编语言中,为什么SI和DI不能同时使用汇编 其实你可以 ... -
int 21h以及汇编的DOS调用
2011-04-01 10:33 3739很多初学汇编语言的同学可能会对INT 21H这条指令感到困惑, ... -
汇编的移位如rol和逻辑运算具体对标志位的影响(转)
2011-03-29 14:42 3503AND XOR TEST SHL SAL ROL RCL ... -
汇编的标志位阐明
2011-03-22 16:10 15201、进位标志CF(Carry Fl ... -
哪些指令会改变汇编的标志位(再附个总结)
2011-03-22 15:08 5714这些书上都没有现成的答案,需要自己总结,感谢BEYOND ... -
汇编一种清零的方法------异或
2011-03-21 11:25 4379清零 常看见的有mov BX 0,但也有很多时候,采用命令 ... -
算术移位操作和逻辑移位操作的区别和联系(转)
2011-03-19 14:07 9100移位操作有很多种,一般知道算术移位操作(2个),逻辑移位( ... -
一字节BCD码转ASCII码的算法及源码
2011-03-19 13:13 6046一字节压缩BCD码是两位0~9的数字,4位二进制数对应一 ... -
汇编术语快速阐明
2011-03-19 10:52 1181教科书式教学的遗毒是人们明知道是晦涩的教条,仍然对其容 ... -
1 汇编开篇
2011-03-17 23:02 1228一直很讨厌汇编的两个词“字”,“伪指令”。直接说“双字节” ...
相关推荐
汇编语言指令汇总,含: 80868088汇编语言指令集.doc, IBM-PC汇编语言指令集.doc, MCS-51指令详解.doc, 常见汇编语言指令及解释.doc, 汇编语言命令大全.doc, 汇编语言指令集.doc
本文将对汇编命令及debug命令进行详细介绍,并结合具体的命令用法与应用场景来加深理解。 #### 汇编命令 汇编命令主要用于控制汇编程序的行为,这些命令可以帮助我们更好地管理源代码、数据结构和内存布局等。以下...
汇编DEBUG及命令大全 1. DEBUG的由来 DEBUG的名称来源于1947年,美国青年霍德华·艾肯找到IBM公司为其投资200万美元研制计算机,第一台成品艾肯把它取名为:马克1号,又叫“自动序列受控计算机”。从这时起,IBM...
在本资料中,我们将深入探讨汇编语言的指令集、命令大全以及常见指令的解释。 汇编语言指令集是计算机系统的基础,不同的处理器架构有不同的指令集,例如x86、ARM等。这些指令集包含了各种操作,如数据处理、内存...
这是一本汇编语言命令大全,收集了完整的命令集。希望能提供给大家以学习和工作为辅佐的工具。
OllyICE反汇编教程及汇编命令详解 本资源主要介绍了 OllyICE 反汇编教程及汇编命令详解,涵盖了计算机寄存器的分类、常用指令、算术运算指令、逻辑运算指令、串指令、程序跳转指令等方面的知识。 一、计算机寄存器...
《汇编语言命令查询软件详解》 汇编语言,作为计算机科学的基础,是与机器硬件直接对话的语言。它由一系列特定的指令组成,这些指令对应于计算机硬件的微操作,使得程序员可以精确控制计算机的每一个动作。在学习和...
CEAA自动汇编工具是专为优化和自动化汇编过程而设计的,它提供了一系列强大的命令,帮助开发者更高效、更精确地控制程序的底层操作。以下是对CEAA自动汇编常用命令的详细解析: ### 1. LABEL(标签) `LABEL(标签)...
### 汇编DEBUG命令使用解析及范例大全 #### Debug简介 DEBUG是一个功能强大的工具,主要用于测试和调试MS-DOS可执行文件。通过这个工具,用户能够深入了解程序的内部运行机制,诊断并修复错误。DEBUG支持一系列命令...
- **作用**:显示Debug命令的帮助信息,方便用户了解每个命令的功能及用法。 **2. a 编辑内存** - **命令格式**:`a [address]` - **作用**:允许用户编辑内存中的数据。其中 `[address]` 参数指定要编辑的内存地址...
OllyICE反汇编教程及汇编命令详解
### Debug命令大全(汇编语言) #### 概述 在深入学习汇编语言的过程中,掌握Debug命令至关重要。Debug是一款功能强大的工具,主要用于测试与调试MS-DOS环境下的可执行文件。通过Debug,用户可以直接与系统内存及...
汇编指令大全+很全的汇编指令 汇编指令大全+很全的汇编指令
汇编 debug 命令详解 汇编 debug 命令是汇编语言中的调试命令,用于调试和测试汇编语言程序。这些命令可以帮助开发者快速地查找和解决程序中的错误。 1. 显示命令 D 显示命令 D 用于显示存储单元的内容。该命令有...
总而言之,MASM 32位汇编及指令集的知识点十分丰富,包括寄存器的使用、内存寻址方法、堆栈操作、关键字的用法以及Win32汇编指令的具体应用等。掌握这些知识点对于深入理解计算机系统和编写高效的汇编程序具有重要...
汇编DEBUG命令详解 DEBUG 命令是 DOS 操作系统中的一种调试工具,主要用于汇编语言的编译和调试。下面是 DEBUG 命令的详细解释: 一、直接汇编 DEBUG 命令可以直接将汇编语言语句编译成机器码,并将其存储在内存...
汇编命令工具是程序员用于编写和处理汇编语言程序的重要工具,它们通常包括汇编器、反汇编器、链接器等组件。以下是对这些工具的详细说明: 1. **汇编器(Assembler)**: 汇编器是将汇编语言代码转换成机器可执行...
OllyDbg是一款功能强大的32位反汇编调试器,主要用于逆向工程、恶意软件分析及调试等场景。它提供了丰富的命令集来帮助用户进行深入的调试工作。本文将详细解释OllyDbg中的命令行命令及其部分汇编指令。 #### 命令...
汇编命令整理1 本文档对汇编命令进行了系统的整理和分类,涵盖了基本指令、寄存器、指令格式、debug命令、汇编器的使用等多方面的内容。 基本指令 1. mov指令:用于将源操作数移動到目标操作数中,例如mov ax, ...