mov
功能:用来进行数据传输。
以 “mov A, B”为例,相当于A=B。
具有以下形式:mov 寄存器, 数据;mov 寄存器, 寄存器;mov 寄存器, 内存单元;mov 内存单元, 寄存器;mov 段寄存器,寄存器;
add
功能:用来做加法。
以“add A, B”为例,相当于A=A+B。
具有的形式,和 mov 一样。
sub
功能:用来做减法。
以“sub A, B”为例,相当于A=A-B。
具有的形式,和 mov 一样。
inc,dec
功能:用来自增,自减
以“inc A”为例,相当于A=A+1。
以“dec A”为例,相当于A=A-1。
push
功能:入栈
以“push A”为例,大概相当于:SP=SP-2 ;将A中的内容送入SS:SP指向的内存单元处。
具有以下形式:push 寄存器;push 内存单元;push 段寄存器
pop
功能:出栈
以“pop A”为例,大概相当于:将SS:SP指向的内存单元处的数据送入A中;SP=SP+2。
具有形式和push相同
Loop
功能:实现基于cx的循环功能
以“loop S“为例,大概相当于:cx=cx-1,判断cx中的值,不为0则转至标号处执行程序。
and
功能:逻辑与指令,按位进行与运算。
通过该指令可将操作对象的相应位设置为0,其他位不变。
or
功能:逻辑或指令,按位进行或运算。
通过该指令可将操作对象的相应位设置为1,其他位不变。
mul
功能:乘法指令
当乘数是字节操作数时,把AL中的无符号数与乘数相乘,结果16位放入AX中
当乘数是字操作数时,把AX中的无符号数与乘数相乘,结果32位,高位放入DX中,低位放入AX中。
div
功能:除法指令
除数:有8位和16位两种,在一个reg或内存单元中。
被除数:默认放在AX或DX和AX中,如果除数为8位,被除数则为16位,默认在AX中存放;如果除数为16位,被除数则为32位,在DX和AX中存放,DX存放高16位,AX存放低16位。
结果:如果除数为8位,则AL存储除法操作的商,AH存储除法操作的余数;如果除数为16位,则AX存储除法操作的商,DX存储除法操作的余数。
jmp
1. 依据位移进行转移的 jmp 指令:
(1) jmp short 标号
这种 jmp指令实现的是段内短转移,它对IP的修改范围为 -128-127 。
实际上,“jmp short 标号”的功能为:(IP)=(IP)+8位位移
8位位移=标号处的地址-jmp指令后的第一个字节的地址。
short指明此处的位移为8位位移。
8位位移用补码表示。
8位位移由编译程序在编译时算出。
(2)jmp near ptr 标号
这种 jmp 指令实现的是段内近转移。
实际上,“jmp near 标号”的功能为:(IP)=(IP)+16位位移
2. 转移的目的地址在指令中的 jmp 指令
jmp far ptr 标号 实现的是段间转移,又称为远转移。
功能:(CS)= 标号所在段的段地址,(IP)= 标号所在段中的偏移地址
3. 转移地址在寄存器中的 jmp 指令
指令格式:jmp 16位 reg
功能:(IP)=(16位reg)
4.转移地址在内存单元中的 jmp 指令
(1)jmp word ptr 内存单元地址
功能:从内存单元地址处开始存放着一个字,是转移的目的偏移地址。
(2)jmp dword ptr 内存单元地址(段间转移)
功能:从内存单元地址处开始存放着两个字,高地址处的字是转移的目的地址,低地址处是转移的目的偏移地址。
jcxz(jump if cx = zero)
指令格式:jcxz 标号
操作:当 cx=0 时,(IP)=(IP)+8位位移
ret
ret指令用栈中的数据,修改IP的内容,从而实现近转移;
CPU执行 ret 指令时,进行下面两步操作:
(1)(IP)=((ss)*16+(sp))
(2)(sp)=(sp)+ 2
retf
retf指令用栈中的数据,修改CS和IP的内容,从而实现远转移;
CPU执行 retf 指令时,进行下面4步操作:
(1)(IP)=((ss)*16 + (sp))
(2)(sp)=(sp)+ 2
(3)(CS)=((ss)*16 + (sp))
(4)(sp)=(sp)+ 2
call
一. 依据位移进行转移的call指令
1. call 标号(将当前的 IP 压栈后,转到标号处执行指令)
CPU执行这种格式的call指令后,进行如下的操作:
(1)(sp)=(sp)- 2
((ss)* 16 +(sp))=(IP)
(2)(IP)=(IP)+ 16位位移
二. 转移的目的地址在指令中的call指令
1. call far ptr 标号
CPU执行此种格式的call指令时,进行如下的操作:
(1)(sp)=(sp)- 2
((ss)*16 + (sp))=(CS)
(sp)=(sp)- 2
((ss)*16 + (sp))=(IP)
(2)(CS)=标号所在段的段地址
(IP)=标号在段中的偏移地址
三. 转移地址在寄存器中的call指令
call 16位 reg
功能:
(sp)=(sp)- 2
((ss)*16 +(sp))=(IP)
(IP)=(reg)
四. 转移地址在内存中的call指令
1. call word ptr 内存单元地址
功能:
push IP
jmp word ptr 内存单元地址
2. call dwordd ptr 内存单元地址
功能:
push CS
push IP
jmp dword ptr 内存单元地址
adc
adc是带进位加法指令,它利用了CF位上记录的进位值。
指令格式:adc 操作对象1,操作对象2
功能:操作对象1=操作对象1+操作对象2+CF
sbb
sbb是带借位减法指令,它利用了CF位上记录的借位值。
指令格式:sbb 操作对象1,操作对象2
功能:操作对象1=操作对象1-操作对象2-CF
cmp
cmp是比较指令,cmp的功能相当于减法指令,只是不保存结果,关键作用是对标志寄存器的影响。
指令格式:cmp 操作对象1,操作对象2
功能:计算操作对象1-操作对象2但不保存结果,仅仅根据计算结果对标志寄存器进行设置。
检测比较结果的条件转移指令
指令
含义
检测的相关标志位
je
等于则跳转
zf=1
jne
不等于则跳转
zf=0
jb
小于则跳转
cf=1
jnb
不小于则跳转
cf=0
ja
大于则跳转
cf=0且zf=0
jna
不大于则跳转
cf=1且zf=1
movsb
格式:movsb
功能:将ds:si指向的内存单元中的字节送入es:di中,然后根据df的值,将si和di递增1或递减1。
执行movsb指令相于进行下面几步操作
(1)((es)*16+(di))=((ds)*16+(si))
(2)如果df=0则:(si)=(si)+ 1;(di)=(di)+ 1
如果df=1则:(si)=(si)- 1;(di)=(di)- 1
movsw
格式:movsw
功能:将ds:si指向的内存字单元中的字送入es:di中,然后根据标志寄存器df的值,将si和di递增2或递减2 。
rep
一般和movsb,movsw联动
功能:rep的作用是根据cx的值,重复执行后面的串传送指令。
pushf ,popf
pushf的功能是将标志寄存器的值压栈,popf的功能是从栈中弹出数据,放入标志寄存器中。
int
功能:引发中断过程。
指令格式:int n (n为中断类型码)
cpu执行int n指令,相当于引发一个n号中断的中断过程,执行过程如下。
(1)取中断类型码n;
(2)标志寄存器入栈,IF=0,TF=0;
(3)CS、IP入栈;
(4)(IP)=(n*4),(CS)=(n*4+2)。
iret
功能:从中断例程返回到应用程序。
相当于:
pop IP
pop CS
popf
in out
在in和out指令中,只能使用ax或al来存放从端口中读入的数据或要发送到端口中的数据。访问8位端口时,要用al;访问16位端口时,要用ax。
对0~255以内的端口进行读写时:
in al,20h ;从20h端口读入一个字节
out 20h,al ;往20h端口写入一个字节
对256~65535的端口进行读写时,端口号放在dx中:
mov dx,3f8h ;将端口号3f8h放入dx
in al,dx ;从3f8h端口读入一个字节
out dx,al ;往3f8h端口写入一个字节
shl
shl是逻辑左移指令,它的功能为:
(1)将一个寄存器或内存单元中的数据向左移位;
(2)将最后移出的一位写入CF中;
(3)最低位用0补充。
如果移动位数大于1时,必须将移动位数放在cl中。
shr
shr是逻辑右移指令,它的功能为:
(1)将一个寄存器或内存单元中的数据向右移位;
(2)将最后移出的一位写入CF中;
(3)最高位用0补充。
如果移动位数大于1时,必须将移动位数放在cl中。
sti cli
sti,设置IF=1
cli,设置IF=0