汇编语言指令详解Word文档下载推荐.docx
《汇编语言指令详解Word文档下载推荐.docx》由会员分享,可在线阅读,更多相关《汇编语言指令详解Word文档下载推荐.docx(30页珍藏版)》请在冰豆网上搜索。
若是16位的,则存储时低位在前,高位在后。
当即寻址主要用来给寄放器或存储器赋初值。
2.直接寻址
操作数地址的16位偏移量直接包括在指令中。
它与操作码—起寄存在代码段区域,操作数一般在数据段区域中,它的地址为数据段寄放器DS加上这16位地址偏移量。
如图2-2所示。
MOVAX,DS:
[2000H];
图2-2
(对DS来讲能够省略成MOVAX,[2000H],系统默以为数据段)
这种寻址方式是以数据段的地址为基础,可在多达64KB的范围内寻觅操作数。
8086/8088中允许段超越,即还允许操作数在以代码段、堆栈段或附加段为基准的区域中。
现在只要在指令中指明是段超越的,则16位地址偏移量能够与CS或SS或ES相加,作为操作数的地址。
MOVAX,[2000H];
数据段
MOVBX,ES:
[3000H];
段超越,操作数在附加段
即绝对地址=(ES)*16+3000H
3.寄放器寻址
操作数包括在CPU的内部寄放器中,如寄放器AX、BX、CX、DX等。
MOVDS,AX
MOVAL,BH
4.寄放器间接寻址
操作数是在存储器中,可是,操作数地址的16位偏移量包括在以下四个寄放器SI、DI、BP、BX之一中。
能够分成两种情形:
(1)以SI、DI、BX间接寻址,则通常操作数在现行数据段区域中,即数据段寄放器(DS)*16加上SI、DI、BX中的16位偏移量,为操作数的地址,
例如:
MOVAX,[SI]操作数地址是:
(DS)*16+(SI)
(2)以寄放器BP间接寻址,则操作数在堆栈段区域中。
即堆栈段寄放器(SS)*16与BP的内容相加作为操作数的地址,
MOVAX,[BP]操作数地址是:
(SS)*16+(BP)
若在指令中规定是段超越的,则BP的内容也能够与其它的段寄放器相加,形成操作数地址。
[BP]操作数地址是:
(DS)*16+(BP)
5.变址寻址
由指定的寄放器内容,加上指令中给出的8位或16位偏移量(固然要由一个段寄放器作为地址基准)作为操作数的偏移地址。
(操作数在存贮器中)
能够作为寄放器变址寻址的四个寄放器是SI、DI、BX、BP。
⑴若用SI、DI和BX作为变址,则与数据段寄放器相加,形成操作数的地址即默许在数据段;
⑵若用BP变址,则与堆栈段寄放器相加,形成操作数的地址即默许在堆栈段
MOVAX,COUNT[SI];
操作数地址是:
(DS)*16+(SI)+COUNT
可是,只要在指令中指定是段超越的,则能够用别的段寄放器作为地址基准。
6.基址加变址寻址
把BX和BP看成是基址寄放器,把SI、DI看着是变址寄放器,把一个基址寄放器(BX或BP)的内容加上一个变址寄放器(SI或DI)的内容,再加上指令中指定的8位或16位偏移量(固然要以一个段寄放器作为地址基准)作为操作数的偏移地址,如图所示。
操作数在存贮器中,其偏移地址由(基址寄放器)+(变址寄放器)+相对偏移量形成
基址寄放器――BX:
数据段、BP:
堆栈段;
变址寄放器――SI、DI。
MOVAX,[BX][SI]或MOVAX,[BX+SI]
也可放置一个相对偏移量,如COUNT、MASK等等,用于表示相对寻址。
MOVAX,MASK[BX][SI]
MOVBH,COUNT[DI][BP];
MOVBH,COUNT[BP+DI]
✧若用BX作为基地址,则操作数在数据段区域
✧若用BP作为基地址,则操作数在堆栈段区域
但如果在指令中规定段是超越的,则可用其它段寄放器作为地址基准。
P.28表2-1段寄放器利用的大体约定
访问存储器类型
默认段寄存器
可指定段寄存器
段内偏移地址来源
取指令码
CS
无
IP
堆栈操作
SS
SP
串操作源地址
DS
CS、ES、SS
SI
串操作目的地址
ES
DI
BP用作基址寄存器
CS、DS、ES
根据寻址方式求得有效地址
一般数据存取
习题与试探:
1.假定DS=2000H,ES=2100H,SS=1500H,SI=00A0H,BX=0100H,BP=0010H,数据变量VAL的偏移地址为0050H,请指出下列指令源操作数是什么寻址方式?
其物理地址是多少?
(1)MOVAX,0ABH
(2)MOVAX,[100H]
(3)MOVAX,VAL(4)MOVBX,[SI]
(5)MOVAL,VAL[BX](6)MOVCL,[BX][SI]
(7)MOVVAL[SI],BX(8)MOV[BP][SI],100
2.已知SS=0FFA0H,SP=00B0H,先执行两条把8057H和0F79H别离进栈的PUSH指令,再执行一条POP指令,试画出堆栈区和SP内容转变的进程示用意。
(标出存储单元的地址)
第二讲
指令系统--数据传输、算术运算
回顾:
8086/8088的内部结构和寄放器,8086/8088的工作进程。
8086/8088的寻址方式及操作数地址的计算。
要求学生了解指令的功能,掌握数据传送类,算术运算类指令的利用方式。
(掌握指令内涵,会用)
8086/8088指令系统
8086/8088的指令系统能够分为以下六个功能组。
1.数据传送(DataTranster)2.算术运算(Arithmetic)
3.逻辑运算(Logic)4.串操作(Stringmenipulation)
5.程序控制(ProgramControl)6.处置器控制(ProcessorControl)
一、数据传送指令
主要介绍MOV,XCHG、堆栈和地址传送指令。
1.数据传送MOV指令
一般格式:
MOVOPRD1,OPRD2
MOV是操作码,OPRD1和OPRD2别离是目的操作数和源操作数。
功能:
完成数据传送
具体来讲,一条数据传送指令能实现:
⑴CPU内部寄放器之间数据的任意传送(除代码段寄放器CS和指令指针IP之外)。
MOVAL,BL;
字节传送
MOVCX,BX;
字传送
MOVDS,BX
⑵当即数传送至CPU内部的通用寄放器组(即AX、BX、CX、DX、BP、SP、SI、DI),
MOVCL,4
MOVAX,03FFH
MOVSI,057BH
⑶CPU内部寄放器(除CS和IP之外)与存储器(所有寻址方式)之间的数据传送。
MOVAL,BUFFER
MOVAX,[SI]
MOV[DI],CX
MOVSI,BLOCK[BP]
MOVDS,DATA[SI+BX]
MOVDEST[BP+DI],ES
⑷能实现用当即数给存储单元赋值
MOV[2000H],25H
MOV[SI],35H
对于MOV指令应注意几个问题:
①存储器传送指令中,不允许对CS和IP进行操作;
②两个操作数中,除当即寻址之外必需有一个为寄放器寻址方式,即两个存储器操作数之间不允许直接进行信息传送;
如咱们需要把地址(即段内的地址偏移量)为AREAl的存储单元的内容,传送至同一段内的地址为AREA2的存储单元中去,MOV指令不能直接完成如此的传送,但咱们能够用CPU内部寄放器为桥梁来完成如此的传送:
MOVAL,AREAl
MOVAREA2,AL
③两个段寄放器之间不能直接传送信息,也不允许用当即寻址方式为段寄放器赋初值;
如:
MOV AX,0;
MOV DS,AX
④目的操作数,不能用当即寻址方式。
2.堆栈指令
(简述堆栈的概念及存取特点,如先进后出)
包括入栈(PUSH)和出栈(POP)指令两类。
仅能进行字运算。
(操作数不能是当即数)
⑴入栈指令PUSH
PUSHOPRD
源操作数能够是CPU内部的16位通用寄放器、段寄放器(CS除外)和内存操作数(所有寻址方式)。
入栈操作对象必需是16位数。
将数据压入堆栈
执行步骤为:
SP=SP-2;
[SP]=操作数低8位;
[SP+1]=操作数高8位
PUSHBX
执行进程为:
SP=SP-1,[SP]=BH;
SP=SP-1,[SP]=BL,如图2-8所示。
⑵出栈指令POP
POPOPRD
将数据弹出堆栈
对指令执行的要求同入栈指令。
POPAX图2-8
POP[BX]
POPDS
3.互换指令XCHG
XCHGOPRD1,OPRD2
完成数据互换
这是—条互换指令,把一个字节或一个字的源操作数与目的操作数彼此换。
互换能在通用寄放器与累加器之间、通用寄放器之间、通用寄放器与存储器之间进行。
但段寄放器和当即数不能作为一个操作数,不能在累加器之间进行。
XCHGAL,CL
XCHGAX,DI
XCHGBX,SI
XCHGAX,BUFFER
XCHGDATA[SI],DH
4.累加器专用传送指令
有三种,输入、输出和查表指令。
前两种又称为输入输出指令。
⑴IN指令
INAL,n;
BAL←[n]
INAX,n;
WAX←[n+1][n]
INAL,DX;
BAL←[DX]
INAX,DX;
WAX←[DX+1][DX]
从I/O端口输入数据至AL或AX。
输入指令允许把一个字节或一个字由一个输入端口传送到AL或AX中。
若端口地址超过255时,则必需用DX保留端口地址,如此用DX作端口寻址最多可寻觅64K个端口。
⑵OUT指令
OUTn,AL;
BAL→[n]
OUTn,AX;
WAX→[n+1][n]
OUTDX,AL;
BAL→[DX]
OUTDX,AX;
WAX→[DX+1][DX]
将AL或AX的内容输出至I/O端口。
该指令将AL或AX中的内容传送到一个输出端口。
端口寻址方式与IN指令相同。
⑶XLAT指令
XLAT;
AL=(DX)×
16+(BX)+(AL))
完成一个字节的查表转换。
要求:
①寄放器AL的内容作为一个256字节的表的下标。
②表的基地址在BX中,③转换后的结果寄存在AL中.TABLE:
MOVBX,OFFSETTABLE
MOVAL,8……
INAL,1第9个字符AAH
查表
OUT1,AL;
(AL)=AAH表长度256
本指令可用在数制转换、函数表查表、代码转换等场合。
5.地址传送指令(有三条地址传送指令)
⑴LEA(LoadEffectiveAddress)
LEAOPRD1,OPRD2
把源操作数OPRD2的地址偏移量传送至目的操作数OPRD1。
①源操作数必需是一个内存操作数,②目的操作数必需是一个16位的通用寄放器。
这条指令通常常利用来成立串操作指令所须的寄放器指针。
例:
LEABX,BUFR;
把变量BUFR的地址偏移量部份送到BX
⑵LDS(LoadpointerintoDS)
LDSOPRD1,OPRD2
完成一个地址指针的传送。
地址指针包括段地址部份和偏移量部份。
指令将段地址送入DS,偏移量部份送入一个16位的指针寄放器或变址寄放器。
源操作数是一个内存操作数,目的操作数是一个通用寄放器/变址寄放器。
LDSSI,[BX];
将把BX所指的32位地址指针的段地址部份送入DS,偏移量部份送入SI。
图2-9LDS指令示意
如图2-9所示。
⑶LES(LoadpointerintoES)
LESOPRD1,OPRD2
这条指令除将地址指针的段地址部份送入ES外,与LDS类似。
LESDI,[BX+COUNT]
6.标志寄放器传送(有四条标志传送指令)
⑴LAHF(LOADAHWITHFLAG)
将标志寄放器中的SF、ZF、AF、PF和CF(即低8位)传送至AH寄放器的指定位,空位没有概念。
⑵SAHF(STOREAHWITHFLAG)
将寄放器AH的指定位,送至标志寄放器的SF、ZF、AF、PF和CF位(即低8位)。
按照AH的内容,影响上述标志位,对OF、DF和IF无影响。
⑶PUSHF(PUSHFLAG)
将标志寄放器压入堆栈顶部,同时修改堆栈指针,不影响标志位。
⑷POPF(POPFLAG)
堆栈顶部的一个字,传送到标志寄放器,同时修改堆栈指针,影响标志位。
二、算术运算指令
8086/8088提供加、减、乘、除四种大体算术操作。
这些操作都可用于字节或字的运算,也能够用于带符号数与无符号数的运算。
带符号数用补码表示。
同时8086/8088也提供了各类校正操作,故能够进行十进制算术运算。
参与加、减运算的操作数可如上图所示。
1.加法指令(Addition)
⑴一般形式:
ADDOPRD1,OPRD2
OPRD1←OPRD1+OPRD2
完成两个操作数相加,结果送至目的操作数OPRD1。
目的操作数能够是累加器,任一通用寄放器和存储器操作数。
ADDAL,30;
累加器与立即数相加
ADDBX,[3000H];
通用寄存器与存储单元内容相加
ADDDI,CX;
通用寄存器之间
ADDDX,DATA[BX+SI];
ADDBETA[SI],DX;
存储器操作数与寄存器相加
这些指令对标志位CF、DF、PF、SF、ZF和AF有影响。
⑵一般形式:
ADCOPRD1,OPRD2;
带进位的加法
OPRD1←OPRD1+OPRD2+CF
这条指令与上—条指令类似,只是在两个操作数相加时,要把进位标志CF的现行值加上去,结果送至目的操作数。
ADC指令主要用于多字节运算中。
如有两个四字节的数,已别离放在自FIRST和SECOND开始的存储区中,每一个数占四个存储单元。
寄存时,最低字节在地址最低处,则可用以下程序段实现相加。
MOVAX,FIRST
ADDAX,SECOND;
进行字运算
MOVTHIRD,AX
MOVAX,FIRST+2
ADCAX,SECOND+2
MOVTHIRD+2,AX
这条指令对标志位的影响与ADD相同。
⑶一般形式:
INCOPRD;
OPRD←OPRD+1
完成对指定的操作数OPRD加1,然后返回此操作数。
此指令主要用于在循环程序中修改地址指针和循环次数等。
这条指令执行的结果影响标志位AF、OF、PF、SF和ZF,而对进位标志没有影响。
INCAL
INC[BX]
2.减法指令(Subtraction)
SUBOPRD1,OPRD2;
OPRD1←OPRD1-OPRD2
完成两个操作数相减,也即从OPRD1中减去OPRD2,结果放在OPRD1中。
SUBCX,BX
SUB[BP],CL
SBBOPRD1,OPRD2;
OPRD1←OPRD1-OPRD2-CF
这条指令与SUB类似,只是在两个操作数相减时,还要减去借位标志CF的现行值.本指令对标志位AF、CF、OF、PF、SF和ZF都有影响。
同ADC指令一样,本指令主要用于多字节操作数相减。
DECOPRD;
OPRD←OPRD-1-CF
对指令的操作数减1,然后送回此操作数,
在相减时,把操作数作为一个无符号二进制数来对待。
指令执行的结果,影响标志AF、OF、PF、SF和ZF.但对CF标志不影响(即维持此指令以前的值)。
DEC[SI]
DECCL
⑷一般形式:
NEGOPRD
(NEGDate) 取补
对操作数取补,即用零减去操作数,再把结果送回操作数。
NEGAL
NEGMULRE
(AL=0011 1100)则取补后为1100 0100
即0000 0000-0011 1100=1100 0100
若在字节操作时对-128,或在字操作时对-32768取补,则操作数没转变,但标志OF置位。
此指令影响标志AF、CF、OF、PF、SF和ZF。
此指令的结果一般老是使标志CF=1。
除非在操作数为零时,才使CF=0。
⑸一般形式:
CMPOPRD1,OPRD2;
OPRD1-OPRD2
比较指令完成两个操作数相减,使结果反映在标志位上,但并非送回结果(即不带回送的减法)。
CMPAL,100
CMPDX,DI
CMPCX,COUHT[BP]
CMPCOUNT[SI],AX
比较指令主要用于比较两个数之间的关系。
在比较指令以后,按照ZF标志即可判断二者是不是相等。
✧相等的比较:
①若二者相等,相减以后结果为零,ZF标志为1,不然为0。
②若二者不相等,则可在比较指令以后利用其它标志位的状态来肯定二者的大小。
✧大小的比较:
若是是两个无符号数(如CMP AX,BX)进行比较,则能够按照CF标志的状态判断两数大小。
若结果没有产生借位(CF=0),显然AX≥BX;
若产生了借位(即CF=1),则AX<BX。
1.设有关寄放器及存储单元的内容如下:
DS=2000H,BX=0100H,AX=1200H,SI=0002H,[20100H]=12H,[20101H]=34H,[20102H]=56H,[20103]=78H,[21200]=2AH,[21201H]=4CH,[21202H]=0B7H,[21203H]=65H。
试说明下列各条指令单独执行后相关寄放器或存储单元的内容。
(1)MOVAX,1800H
(2)MOVAX,BX
(3)MOVBX,[1200H](4)MOVDX,1100[BX]
(5)MOV[BX][SI],AL(6)MOVAX,1100[BX][SI]
2.写出实现下列计算的指令序列。
(假定X、Y、Z、W、R都为字变量)
(1)Z=W+(Z+X)
(2)Z=W-(X+6)-(R+9)
3.若在数据段中从字节变量TABLE相应的单元开始寄存了0~15的平方值,试写出包括有XLAT指令的指令序列查找N(0~15)中的某个数的平方。
(设N的值寄存在CL中)
第三讲
指令系统-算术运算、逻辑运算、控制转移
要求学生了解指令的功能,掌握算术运算类、逻辑运算和移位指令的功能和应用。
讲述内容:
3.乘法指令(分为无符号乘法指令和带符号乘法指令两类)
(1)无符号乘法指令MUL
一般格式:
MULOPRD
完成字节与字节相乘、字与字相乘,且默许的操作数放在AL或AX中,而源操作数由指令给出。
8位数相乘,结果为16位数,放在AX中;
16位数相乘结果为32位数,高16位放在DX,低16位放在AX中。
注意:
源操作数不能为当即数。
MOVAL,FIRST;
MULSECOND;
结果为AX=FIRST*SECOND
MOVAX,THIRD;
MULAX;
结果DX:
AX=THIRD*THIRD
MOVAL,30H
CBW;
字扩展AX=30H
MOVBX,2000H
MULBX;
(2)带符号数乘法指令IMUL
一般格式:
IMULOPRD;
OPRD为源操作数
这是一条带符号数的乘法指令,同MUL一样能够进行字节与字节、字和字的乘法运算。
结果放在AX或DX,AX中。
当结果的高半部份不是结果的低半部份的符号扩展时,标志位CF和OF将置位。
4.除法指令
(1)无符号数除法指令DIV
DIVOPRD
(2)带符号数除法IDIV
IDIVOPRD
该指令执行进程同DIV指令,但IDIV指令以为操作数的最高位为符号位,除法运算的结果商的最高位也为符号位。
在除法指令中,在字节运算时被除数在AX中;
运算结果商在AL中,余数在AH中。
字运算时被除数为DX:
AX组成的32位数,运算结果商在AX中,余数在DX中。
AX=2000H,DX=200H,BX=1000H,则DIVBX执行后,AX=2002H,DX=0000。
除法运算中,源操作数可为除当即寻址方式之外的任何一种寻址方式,且指令执行对所有的标志位都无概念。
由于除法指令中的字节运算要求被除数为16位数,而字运算要求被除数是32位数,在8086/8088系统中往往需要用符号扩展的方式取得被除数所要的格式,因此指令系统中包括两条符号扩展指令。
(3)字节扩展指令CBW
CBW
该指令执行时将AL寄放器的最高位扩展到AH,即若D7=0,则AH=0;
不然AH=0FFH。
(4)字扩展指令CWD
CWD
该指令执行时将AX寄放器的最高位扩展到DX,即若D15=0,则DX=0;
不然DX=0FFFFH。
CBW、CWD指令不影响标志位。
5.十进制调整指令
运算机中的算术运算,都是针对二进制数的运算,而人们在日常生活中适应利用十进制。
为此在8086/8088系统中,针对十进制算术运算有一类十进制调整指