dx 汇编dec_汇编语言——汇编指令

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


版权声明:本文为weixin_36222664原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。