当前位置:文档之家› 汇编语言指令分类详解

汇编语言指令分类详解

3.1 8086/8088寻址方式计算机中的指令由操作码字段和操作数字段组成。

操作码:指计算机所要执行的操作,或称为指出操作类型,是一种助记符。

操作数:指在指令执行操作的过程中所需要的操作数。

该字段除可以是操作数本身外,也可以是操作数地址或是地址的一部分,还可以是指向操作数地址的指针或其它有关操作数的信息。

寻址方式就是指令中用于说明操作数所在地址的方法,或者说是寻找操作数有效地址的方法。

8086/8088的基本寻址方式有六种。

1.立即寻址所提供的操作数直接包含在指令中。

它紧跟在操作码的后面,与操作码一起放在代码段区域中。

如图所示。

例如:MOV AX,3000H立即数可以是8位的,也可以是16位的。

若是16位的,则存储时低位在前,高位在后。

立即寻址主要用来给寄存器或存储器赋初值。

2.直接寻址操作数地址的16位偏移量直接包含在指令中。

它与操作码—起存放在代码段区域,操作数一般在数据段区域中,它的地址为数据段寄存器DS加上这16位地址偏移量。

如图2-2所示。

例如:MOV AX,DS:[2000H];图2-2(对DS来讲可以省略成MOV AX,[2000H],系统默认为数据段)这种寻址方法是以数据段的地址为基础,可在多达64KB的范围内寻找操作数。

8086/8088中允许段超越,即还允许操作数在以代码段、堆栈段或附加段为基准的区域中。

此时只要在指令中指明是段超越的,则16位地址偏移量可以与CS或SS或ES相加,作为操作数的地址。

MOV AX,[2000H] ;数据段MOV BX,ES:[3000H] ;段超越,操作数在附加段即绝对地址=(ES)*16+3000H3.寄存器寻址操作数包含在CPU的内部寄存器中,如寄存器AX、BX、CX、DX等。

例如:MOV DS,AXMOV AL,BH4.寄存器间接寻址操作数是在存储器中,但是,操作数地址的16位偏移量包含在以下四个寄存器SI、DI、BP、BX之一中。

可以分成两种情况:(1)以SI、DI、BX间接寻址,则通常操作数在现行数据段区域中,即数据段寄存器(DS)*16加上SI、DI、BX中的16位偏移量,为操作数的地址,例如:MOV AX,[SI] 操作数地址是:(DS)*16+(SI)(2)以寄存器BP间接寻址,则操作数在堆栈段区域中。

即堆栈段寄存器(SS)*16与BP的内容相加作为操作数的地址,例如:MOV AX,[BP] 操作数地址是:(SS)*16+(BP)若在指令中规定是段超越的,则BP的内容也可以与其它的段寄存器相加,形成操作数地址。

例如:MOV AX,DS:[BP] 操作数地址是:(DS)*16+(BP)5.变址寻址由指定的寄存器内容,加上指令中给出的8位或16位偏移量(当然要由一个段寄存器作为地址基准)作为操作数的偏移地址。

(操作数在存贮器中)可以作为寄存器变址寻址的四个寄存器是SI、DI、BX、BP。

⑴若用SI、DI和BX作为变址,则与数据段寄存器相加,形成操作数的地址即默认在数据段;⑵若用BP变址,则与堆栈段寄存器相加,形成操作数的地址即默认在堆栈段例如:MOV AX,COUNT[SI];操作数地址是:(DS)*16+(SI)+COUNT但是,只要在指令中指定是段超越的,则可以用别的段寄存器作为地址基准。

6.基址加变址寻址把BX和BP看成是基址寄存器,把SI、DI看着是变址寄存器,把一个基址寄存器(BX或BP)的内容加上一个变址寄存器(SI或DI)的内容,再加上指令中指定的8位或16位偏移量(当然要以一个段寄存器作为地址基准)作为操作数的偏移地址,如图所示。

操作数在存贮器中,其偏移地址由(基址寄存器)+(变址寄存器)+相对偏移量形成基址寄存器――BX:数据段、BP:堆栈段;变址寄存器――SI、DI。

例如:MOV AX,[BX][SI] 或MOV AX,[BX+SI]也可放置一个相对偏移量,如COUNT 、MASK等等,用于表示相对寻址。

MOV AX,MASK[BX][SI]MOV BH,COUNT[DI][BP];MOV BH,COUNT[BP+DI]✧若用BX作为基地址,则操作数在数据段区域✧若用BP作为基地址,则操作数在堆栈段区域但若在指令中规定段是超越的,则可用其它段寄存器作为地址基准。

3.2 指令系统8086/8088的指令系统可以分为以下六个功能组。

1.数据传送(Data Transter) 2.算术运算(Arithmetic)3.逻辑运算(Logic) 4.串操作(String menipulation)5.程序控制(Program Control) 6.处理器控制(Processor Control)一、数据传送指令主要介绍MOV,XCHG、堆栈和地址传送指令。

1.数据传送MOV指令一般格式:MOV OPRD1,OPRD2MOV 是操作码,OPRD1和OPRD2分别是目的操作数和源操作数。

功能:完成数据传送具体来说,一条数据传送指令能实现:⑴CPU内部寄存器之间数据的任意传送(除了代码段寄存器CS和指令指针IP以外)。

MOV AL,BL;字节传送MOV CX,BX;字传送MOV DS,BX⑵立即数传送至CPU内部的通用寄存器组(即AX、BX、CX、DX、BP、SP、SI、DI),MOV CL,4MOV AX,03FFHMOV SI,057BH⑶CPU内部寄存器(除了CS和IP以外)与存储器(所有寻址方式)之间的数据传送。

MOV AL,BUFFERMOV AX,[SI]MOV [DI],CXMOV SI,BLOCK[BP]MOV DS,DA TA[SI+BX]MOV DEST[BP+DI],ES⑷能实现用立即数给存储单元赋值例如:MOV [2000H],25HMOV [SI],35H对于MOV 指令应注意几个问题:①存储器传送指令中,不允许对CS和IP进行操作;②两个操作数中,除立即寻址之外必须有一个为寄存器寻址方式,即两个存储器操作数之间不允许直接进行信息传送;如我们需要把地址(即段内的地址偏移量)为AREAl的存储单元的内容,传送至同一段内的地址为AREA2的存储单元中去,MOV指令不能直接完成这样的传送,但我们可以用CPU内部寄存器为桥梁来完成这样的传送:MOV AL,AREAlMOV AREA2,AL③两个段寄存器之间不能直接传送信息,也不允许用立即寻址方式为段寄存器赋初值;如:MOV AX,0;MOV DS,AX④目的操作数,不能用立即寻址方式。

2.堆栈指令(简述堆栈的概念及存取特点,如先进后出)包括入栈(PUSH)和出栈(POP)指令两类。

仅能进行字运算。

(操作数不能是立即数)⑴入栈指令PUSH一般格式:PUSH OPRD源操作数可以是CPU内部的16位通用寄存器、段寄存器(CS除外)和内存操作数(所有寻址方式)。

入栈操作对象必须是16位数。

功能:将数据压入堆栈执行步骤为:SP=SP-2;[SP]=操作数低8位;[SP+1]= 操作数高8位例如:PUSH BX执行过程为:SP=SP-1,[SP]=BH;SP=SP-1,[SP]=BL,如图2-8所示。

⑵出栈指令POP一般格式:POP OPRD功能:将数据弹出堆栈对指令执行的要求同入栈指令。

例如:POP AX 图2-8POP [BX]POP DS3.交换指令XCHG一般格式:XCHG OPRD1,OPRD2功能:完成数据交换这是—条交换指令,把一个字节或一个字的源操作数与目的操作数相交换。

交换能在通用寄存器与累加器之间、通用寄存器之间、通用寄存器与存储器之间进行。

但段寄存器和立即数不能作为一个操作数,不能在累加器之间进行。

例如:XCHG AL,CLXCHG AX,DIXCHG BX,SIXCHG AX,BUFFERXCHG DA TA[SI],DH4.累加器专用传送指令有三种,输入、输出和查表指令。

前两种又称为输入输出指令。

⑴IN 指令一般格式:IN AL,n ; B AL←[n]IN AX,n ;W AX←[n+1][n]IN AL,DX ;B AL←[DX]IN AX,DX ;W AX←[DX+1][DX]功能:从I/O端口输入数据至AL或AX。

输入指令允许把一个字节或一个字由一个输入端口传送到AL或AX中。

若端口地址超过255时,则必须用DX保存端口地址,这样用DX作端口寻址最多可寻找64K个端口。

⑵OUT 指令一般格式:OUT n,AL ; B AL→[n]OUT n,AX ;W AX→[n+1][n]OUT DX,AL ; B AL→[DX]OUT DX,AX ;W AX→[DX+1][DX]功能:将AL或AX的内容输出至I/O端口。

该指令将AL或AX中的内容传送到一个输出端口。

端口寻址方式与IN 指令相同。

⑶XLA T指令一般格式:XLA T ;AL=(DX)×16+(BX)+(AL))功能:完成一个字节的查表转换。

要求:①寄存器AL的内容作为一个256字节的表的下标。

②表的基地址在BX 中,③转换后的结果存放在AL中. TABLE:例如:MOV BX,OFFSET TABLEMOV AL,8 ……IN AL,1 第9个字符AAHXLA T ;查表OUT 1,AL ;(AL)=AAH表长度256本指令可用在数制转换、函数表查表、代码转换等场合。

5.地址传送指令(有三条地址传送指令)⑴LEA (Load Effective Address)一般格式:LEA OPRD1,OPRD2功能:把源操作数OPRD2的地址偏移量传送至目的操作数OPRD1。

要求:①源操作数必须是一个内存操作数,②目的操作数必须是一个16位的通用寄存器。

这条指令通常用来建立串操作指令所须的寄存器指针。

例:LEA BX,BUFR;把变量BUFR的地址偏移量部分送到BX⑵LDS (Load pointer into DS)一般格式:LDS OPRD1,OPRD2功能:完成一个地址指针的传送。

地址指针包括段地址部分和偏移量部分。

指令将段地址送入DS,偏移量部分送入一个16位的指针寄存器或变址寄存器。

要求:源操作数是一个内存操作数,目的操作数是一个通用寄存器/变址寄存器。

例如:LDS SI,[BX] ;将把BX所指的32位地址指针的段地址部分送入DS,偏移量部分送入SI。

图2-9 LDS指令示意如图2-9所示。

⑶LES (Load pointer into ES)一般格式:LES OPRD1,OPRD2这条指令除将地址指针的段地址部分送入ES外,与LDS类似。

例如:LES DI,[BX+COUNT]6.标志寄存器传送(有四条标志传送指令)⑴LAHF (LOAD AH WITH FLAG)将标志寄存器中的SF、ZF、AF、PF和CF(即低8位)传送至AH寄存器的指定位,空位没有定义。

相关主题