指令和数据的寻址方式
指令和数据的寻址方式

4.5.2 基本指令系统
指令系统的基本指令见表4.7。
4.5.3 精简指令系统
RISC指令系统的特征:
选取使用频率最高的一些简单指令;(指令总数较少) 指令长度固定,指令格式种类少,寻址方式种类少; 只有取数/存数指令访问存储器,其余的指令操作都在寄存器之间进行。
因此,RISC的CPU的寄存器较多。
1. 顺序寻址方式
指令地址在内存中按顺序安排,当执行一段程序时,通常是一条指令接一 条指令的顺序执行。 为此,必须使用程序计数器(又称指令指针寄存器)PC来计数指令的顺序 号,该顺序号就是指令在内存中的地址。
2. 跳跃寻址方式
当程序转移执行的顺序时,指令的寻址就采取跳跃寻址方式。所谓跳跃,是 指下条指令的地址码不是由程序计数器给出,而是由本条指令给出。程序跳 跃后,按新的指令地址开始顺序执行。
4.3 指令和数据的寻址方式
操作数或指令在存储器中的地址:某个操作数或某条指令存放在某个存储单 元时其存储单元的编号。 在存储器中,操作数或指令写入或读出的方式,有三种:地址指定方式、相 联存储方式和 堆栈存储方式。 当采用地址指定方式时,形成操作数或指令地址的方式,称为寻址方式。寻 址方式分为两类,即指令寻址方式和数据寻址方式。 指令的寻址方式有两种,一种是顺序寻址方式,另一种是跳跃寻址方式。 4.3.1 指令的寻址方式
4.3.2 操作数寻址方式
1.
1.
1.
寄存器寻址方式和寄存器间接寻址方式:当操作数不放在内存中,而是 放在CPU的通用寄存器中时,可采用寄存器寻址方式。此时指令中给出的 操作数地址不是内存的地址单元号,而是通用寄存器的编号。 寄存器寻址方式和寄存器间接寻址方式的区别在于:指令中的寄存器内 容不是操作数,而是操作数的地址,该地址指明的操作数在内存中。 相对寻址:是把程序计数器PC的内容加上指令格式中的形式地址D而形成 操作数的有效地址。 程序计数器的内容就是当前指令的地址。“相对”寻址,就是相对于当 前的指令地址而言。 采用相对寻址方式的好处是程序员无须用指令的绝对地址编程,所编程 序可以放在内存任何地方。 此时形式地址D通常称为偏移量,其值可正 可负,相对于当前指令地址进行浮动。 基址寻址方式:将CPU中基址寄存器的内容加上指令格式中的形式地址而 形成操作数的有效地址。 它的优点是可以扩大寻址能力。同形式地址相比,基址寄存器的位数可 以设置得很长,从而可以在较大的存储空间中寻址。
指出下列指令中源操作数和目的操作数的寻址方式

1.指出下列指令中源操作数和目的操作数的寻址方式:(1) MOV SI,1000(2) MOV BP,AX(3) MOV [SI],1000(4) MOV BP,[AX](5) AND DL,[BX + SI + 20H](6) PUSH DS(7) POP AX(8) MOV EAX,COUNT[EDX*4](9) IMUL AX,BX,34H(10) JMP FAR PTR LABEL2.指出下列指令语法是否正确,若不正确请说明原因。
(1) MOV DS,0100H(2) MOV BP,AL(3) XCHG AX,2000H(4) OUT 310H,AL(5) MOV BX,[BX](6) MOV ES:[BX + DI],AX(7) MOV AX,[SI + DI](8) MOV SS:[BX + SI + 100H],BX(9) AND AX,BL(10) MOV DX,DS:[BP](11) MOV [BX],[SI](12) MOV CS,[1000](13) IN AL,BX3.设DS = 2000H,BX = 1256H,SI = 528FH,偏移量 = 20A1H,[232F7H] = 3280H,[264E5] = 2450H。
若独立执行下述指令后,请给出对应IP寄存器的内容。
(1) JMP BX;IP=?(2) JMP [BX][SI];IP=?4.32位机中,当用MOVZX和MOVSX指令时,传送执行后,结果有什么区别?试以传送80H为例说明之。
6.有如下程序:MOV AL,45HADD AL,71HDAAMOV BL,ALMOV AL,19HADC AL,12HDAAMOV BH,AL执行后,BX =?标志位PF =?CF =?7.执行下列程序段,指出此程序段功能。
(1) MOV CX,10LEA SI,FirstLEA DI,SecondREP MOVSB(2) CLDLEA DI,ES:[0404H]MOV CX,0080HXOR AX,AXREP STOSW8.试用指令实现:(1) AL寄存器低4位清0;(2) 测试DL寄存器的最低2位是否为0,若是,则将0送入AL寄存器;否则将1送AL 寄存器。
七种寻址方式

七种寻址方式一、立即寻址方式操作数作为指令的一部分而直接写在指令中,这种操作数称为立即数,这种寻址方式也就称为立即数寻址方式。
立即数可以是8位、16位或32位,该数值紧跟在操作码之后。
如果立即数为16位或32位,那么,它将按“高高低低”的原则进行存储。
例如:MOV AH,80H ADD AX,1234H MOV ECX,123456HMOV B1,12H MOV W1,3456H ADD D1,32123456H其中:B1、W1和D1分别是字节、字和双字单元。
以上指令中的第二操作数都是立即数,立即数寻址方式通常用于对通用寄存器或内存单元赋初值。
二、寄存器寻址方式指令所要的操作数已存储在某寄存器中,或把目标操作数存入寄存器。
把在指令中指出所使用寄存器(即:寄存器的助忆符)的寻址方式称为寄存器寻址方式。
指令中可以引用的寄存器及其符号名称如下:8位寄存器有:AH、AL、BH、BL、CH、CL、DH和DL等;16位寄存器有:AX、BX、CX、DX、SI、DI、SP、BP和段寄存器等;32位寄存器有:EAX、EBX、ECX、EDX、ESI、EDI、ESP和EBP等。
寄存器寻址方式是一种简单快捷的寻址方式,源和目的操作数都可以是寄存器。
1、源操作数是寄存器寻址方式如:ADD VARD,EAX ADD VARW,AX MOV VARB,BH等。
其中:VARD、VARW和VARB是双字,字和字节类型的内存变量。
在第4章将会学到如何定义它们。
2、目的操作数是寄存器寻址方式如:ADD BH,78h ADD AX,1234h MOV EBX,12345678H等。
3、源和目的操作数都是寄存器寻址方式如:MOV EAX,EBX MOV AX,BX MOV DH,BL等。
三、直接寻址方式指令所要的操作数存放在内存中,在指令中直接给出该操作数的有效地址,这种寻址方式为直接寻址方式。
在通常情况下,操作数存放在数据段中,所以,其物理地址将由数据段寄存器DS和指令中给出的有效地址直接形成,但如果使用段超越前缀,那么,操作数可存放在其它段。
【计算机组成原理】指令系统-寻址

【计算机组成原理】指令系统-寻址⼀、指令和数据的寻址⽅式操作数或指令在存储器中的地址:某个操作数或某条指令存放在某个存储单元时其存储单元的编号在存储器中,操作数或指令字写⼊或读出的⽅式,有地址指定⽅式、相联存储⽅式和堆栈存取⽅式。
寻找⽅式:当采⽤地址指定⽅式时,形成操作数或指令地址的⽅式。
寻址⽅式分为两类:指令寻址和数据寻址。
1)指令寻址:确定下⼀条预执⾏指令的指令地址a、顺序寻址:(PC)+1->PC 程序计数器⾃动加1b、跳跃寻址:由转移指令指出2)数据寻址:确定本条指令的操作数地址指令中所给出的地址码,并不⼀定是操作数的有效地址。
寻址过程就是把操作数的形式地址,变换为操作数的有效地址。
例如:⼀种单地址指令的结构如下所⽰,其中⽤X I D各字段组成该指令的操作数地址。
⼆、寻址⽅式1、隐含寻址(操作数在累加寄存器中)在指令中不明显的给出⽽是隐含着操作数的地址例如:单地址的指令格式,没有在地址字段指明第⼆操作数地址,⽽是规定累加寄存器AL或AX作为第⼆操作数地址,AL或AX对单地址指令格式来说是隐含地址eg: MOV AL ,LSRC_BYTEMUL RSRC_BYTEADD寻址特征A操作数地址隐含在操作码中,(寻址特征指明寻址类型)。
另⼀个操作数隐含在ACC中先在内存中地址为A的地⽅找到⼀个操作数,另⼀个操作数隐含在寄存器ACC⾥,从ACC⾥取出另外⼀个操作数,然后和给出的A 地址中的数相加暂存在ACC中。
2、⽴即寻址形式地址A就是操作数本⾝OP⽴即寻址特性 #A指令执⾏阶段不访存A的位数限制了⽴即数的范围3、直接寻址EA=A直接根据读内存找到操作数,形式地址不需要经过任何处理。
执⾏阶段访问⼀次存储器A的位数决定了该指令操作数的寻址范围MOV AX,[2222H]:将有效地址为2222H的内存单元的内容读到累加器AX中4、间接寻址EA=(A)有效地址由形式地址间接提供,形式地址是操作数的地址的地址OP间接寻址标识 A根据A的内容到内存中寻找到的是操作的数地址,再根据这个地址去找操作数。
七种寻址方式

七种寻址方式1、立即寻址方式:操作数就包含在指令中。
作为指令的一部分,跟在操作码后存放在代码段。
这种操作数成为立即数。
立即数可以是8位的,也可以是16位的。
例如:指令: MOV AX,1234H则: AX = 1234H2、寄存器寻址方式:操作数在CPU内部的寄存器中,指令指定寄存器号。
对于16位操作数,寄存器可以是:AX、BX、CX、DX、SI、DI、SP 和BP等。
对于8位操作数,寄存器可以是AL 、AH、BL、BH、CL、CH、DL、DH。
这种寻址方式由于操作数就在寄存器中,不需要访问存储器来取得操作数因而可以取得较高的运算数度。
3、直接寻址方式:操作数在寄存器中,指令直接包含有操作数的有效地址(偏移地址)注:操作数一般存放在数据段所以操作数的地址由DS加上指令中直接给出的16位偏移得到。
如果采用段超越前缀,则操作数也可含在数据段外的其他段中。
例如:MOV AX,[8054]如(DS) = 2000H,则执行结果为(AX) = 3050H(物理地址=20000+8054=28054H)28054H里的内容为3050H在汇编语言指令中,可以用符号地址代替数值地址如:MOV AX,VALUE此时VALUE为存放操作数单元的符号地址。
如写成:MOV AX,[VALUE]也是可以的,两者是等效的。
如VALUE在附加段中,则应指定段超越前缀如下:MOV AX,ES:VALUE 或MOV AX,ES:[VALUE]4、寄存器间接寻址方式:操作数在寄存器中,操作数有效地址在SI、DI、BX、BP这四个寄存器之一中。
在一般情况下,如果有效地址在SI、DI和BX中,则以DS段寄存器中的内容为段值。
如果有效地址在BP中,则以SS段寄存器中的内容为段值例如:MOV AX,[SI]如果(DS) = 5000H (SI) = 1234H则物理地址= 50000 + 1234 = 51234H51234H地址中的内容为:6789H执行该指令后,(AX) = 6789H5、寄存器相对寻址方式:操作数在存储器中,操作数的有效地址是一个基址寄存器(BX、BP)或变址寄存器(SI、DI)的内容加上指令中给定的8位或16位位移量之和BX 8位位移量EA(有效地址) = BP +SI 16位位移量DI在一般情况下,如果SI、DI、或BX中的内容作为有效地址的一部分,那么引用的段寄存器是DS;如果BP中的内容作为有效地址的一部分,那么引用的段寄存器是SS。
指令格式及寻址方式

特点:指令中直接给出操作数在段内的偏移量,段基 址隐含给出或用段前缀指明。该寻址方式适用于处理单个变
一般操作数存放在数据段,故操作数的物理地址为 物理地址=(DS)× 16D+ EA
=(段基址的寄存器)× 16 + 偏移地址
1.3与数据有关的寻址方式
【例3.4】已知(DS)=4000H,[42000H]=3355H MOV AX,[2000H]
1.3与数据有关的寻址方式
(3)寄存器相对寻址方式(register relative addressing 特点:操作数的有效地址是一个基址寄存器或变址寄存器的 内容和指令中指定的8位或16位位移量(即偏移量)之和。 适用于表格处理,修改基址或变址寄存器的内容来取得表格
{ 物理地址=16D×(DS){}+
ADD AX, BX
1.18086/8088的通用指令格式
对有操作数的指令,在执行指令所规定的操作之前首 先要寻找操作数。指令中的操作数字段实质上是指出参加 操作运算的操作数存放在何处。一般来说,操作数存放在 指令代码中,称为立即数;操作数存放在CPU寄存器中, 称为寄存器操作数;操作数存放在内存单元中,称为存储 器操作数; 操作数也可存放在I/O端口内。寻找这些操作 数的方式称为寻址方式,即指令中用于说明操作数或操作 数所在地址的方法。
8种寻址方式算法

8种寻址方式算法
寻址方式是计算机指令系统中的一种指令,用于指示程序中操作数的有效地址。
以下是8种常见的寻址方式:
1.立即寻址:操作数直接包含在指令中,即操作码后面紧跟的是
操作数本身。
2.寄存器寻址:操作数存储在寄存器中,指令指定寄存器名。
3.间接寻址:操作数的有效地址通过寄存器间接给出,指令指定
寄存器名。
4.相对寻址:操作数的有效地址是程序计数器的当前值与位移量
之和。
5.变址寻址:操作数是变址寄存器的内容加上一个偏移量。
6.基址寻址:操作数的有效地址是基址寄存器和位移量之和。
7.多重寻址:一个指令中同时使用多个操作数地址来源。
8.堆栈寻址:操作数的有效地址是堆栈指针寄存器和位移量之
和。
以上是8种常见的寻址方式,每种方式都有其特定的应用场景,用于满足不同的数据处理需求。
8051单片机指令系统的7种寻址方式解析

8051单片机指令系统的7种寻址方式解析寻址方式:寻址就是寻找操作数的地址。
绝大多数指令执行时都需要操作数,因此就存在如何确定操作数地址的问题。
所谓寻址方式就是通过什么途径获取操作数的方式。
根据指令操作的需要,计算机总是提供多种寻址方式。
一般来说,寻址方式越多计算机的寻址能力就越强,但指令系统也就越复杂。
8051指令系统有7种寻址方式:寄存器寻址,直接寻址,寄存器间接寻址,立即寻址,基址寄存器加变址寄存器间接寻址,相对寻址,位寻址,下面分别介绍。
寄存器寻址寄存器寻址:寄存器寻址就是操作数在寄存器中,因此指定了寄存器就得到了操作数。
采用寄存器寻址方式的指令都是一字节的指令,指令中以符号名称来表示寄存器。
例如:MOV A R1 这条指令的功能是把工作寄存器R1的内容传送到累加器A中,由于操作数在R1中,因此指令中指定了R1,也就得到了操作数。
寄存器寻址方式的寻址范围包括:工作寄存器组R0~R7,部分特殊寄存器ACC,B,DPTR 等。
直接寻址直接寻址:直接寻址就是在指令中直接给出操作数所在单元的真实地址。
这里给出的操作数直接地址为8位二进制地址。
程序中一般用十六进制数表示。
例如:指令MOV A,30H 把内部RAM单元30H中的数据传送给累加器A,指令中30H就是操作数的直接地址。
直接寻址方式的寻址范围包括:内部数据存储器低128单元,特殊功能寄存器。
特殊功能寄存器在指令的表示中除了可以以直接地址形式给出外,还可以以寄存器符号形式给出,如对累加器A,在指令中可使用其直接地址OEOH,也可使用其符号形式ACC。
立即寻址立即寻址:立即寻址方式就是实际操作数作为指令的一部分,在指令中直接给出,取指令时,可在程序存储器中直接取得操作数。
通常把出现在指令中的操作数称为立即数。
采用立即寻址方式的指令,在立即数前面加上。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
4.3.2 操作数寻址方式
变址寻址方式:把CPU中某个变值寄存器的内容与偏移量D相加来形成操 作数的有效地址。 使用变址寻址方式的目的不在于扩大寻址空间,而在于实现程序块的规 律性变化。 块寻址方式:块寻址方式经常用在输入输出指令中,以实现外存储器或 外围设备同内存之间的数据块传送。块寻址方式在内存中还可用于数据 块搬家。 块寻址时,通常在指令中指出数据块的起始地址(首地址)和 数据块的长度(字数或字节数)。 如果数据块是变长的,可用三种方法指出它的长度: (1)指令中划出字段指出长度; (2)指令格式中指出数据块的首地址与末地址; (3)由块结束字符指出数据块长度。 操作码 首地址 标志位 末地址 段寻址方式:微型机中采用了段寻址方式,例如它们可以给定一个20位 的地址,从而有1M存储空间的直接寻址能力。为此将整个1M空间存储器 以64K为单位划分成若干段。在寻址一个内存具体单元时,由一个基地址 再加上某些寄存器提供的16位偏移量来形成实际的20位物理地址。这个 基地址就是CPU中的段寄存器。
4.3.3 寻址方式举例
PDP/11系列机寻址方式 PDP/11系列机指令字长为16位,虽然指令系统中有单操作数指令和 双操作数指令,但操作数字段即地址部分均由6位二进制构成。例 如双操作数指令为: 15 12 11 9 8 7 6 5 4 3 2 1 0 操作码 寻址方式 寄存器号 寻址方式 寄存器号 |<-------源地址------>|<-------目标地址----->| 参阅表4.4PDP/11系列机的寻址方式,其主要特征是采用寄存器 寻址 PentiБайду номын сангаасm的寻址方式。 Pentium的外部地址总线宽度是36位,但它也支持32位的物理地 址空间。其有效地址的寻址方式共有九种,参见表4.5 Pentium的 寻址方式
这也需要时间。第二种指令的执行时间不会等于第三种 指令,因为第三种指令虽然也访问存储器,但节省了 求有效地址运算的时间开销。 ⑶根据已知条件:MOV(OP)=001010,STA(OP) =011011,LDA(OP)=111100,将指令的十六进制 格式转换成二进制代码且比较后可知:①(F0F1)H (3CD2)H 指令代表LDA指令,编码正确,其含义是 把主存(13CD2)H 地址单元的内容取至15号寄存器。 ②(2856)H 指令代表MOV指令,编码正确,含义是把6 号源寄存器的内容传送至5号目标寄存器。 ③(6FD6)H 是单字长指令,一定是MOV指令,但编码 错误,可改正为(28D6)H ④(1C2)H 是单字长指令,代表MOV指令,但编码错误, 可改正为(28C2)H 。
要求: ⑴分析三种指令的指令格式与寻址方式特点。 ⑵CPU完成哪一种操作所花时间最短?哪一种操作所 花时间最长?第二种指令的执行时间有时会等于第三种指 令的执行时间吗? ⑶下列情况下每个十六进制指令字分别代表什么操作? 其中如果有编码不正确,如何改正才能成为合法指令? ①(F0F1)H (3CD2)H ②(2856)H ③(6FD6)H ④(1C2)H [解]:⑴第一种指令是单字长二地址指令,RR型;第二种指 解 令是双字长二地址指令,RS型,其中S采用基址寻址或变 址寻址,R由源寄存器决定;第三种也是双字长二地址指 令,RS型,其中R由目标寄存器决定,S由20位地址(直 接寻址)决定。 ⑵处理机完成第一种指令所花时间最短,因为是RR型指 令,不需要访问存储器。第二种指令所花时间最长,因为 是RS型指令,需要访问存储器,同时要进行寻址方式的变 换运算(基址或变址),
1. 隐含寻址
在指令中不明显的给出而是隐含着操作数的地址。例如,单地址的指令 格式,没有在地址字段中指明第二操作数地址,而是规定累加寄存器AC 作为第二操作数地址,AC对单地址指令格式来说是隐含地址。
2. 立即寻址
指令的地址字段指出的不是操作数的地址,而是操作数本身。这种方式 的特点是指令执行时间很短,不需要访问内存取数。 例如:单地址的移位指令格式为 OP(移位 移位) OP(移位) F D 这里D不是地址,而是一个操作数。F为标志位,当F=1,操作数进行右 移;当F=0时,操作数进行左移。
4.3.2 操作数寻址方式
直接寻址:是一种基本的寻址方法,其特点是:在指令格式的地址字段中直接 指出操作数在内存的地址D。 采用直接寻址方式时,指令字中的形式地址D就是操作数的有效地址E,既E=D。 因此通常把形式地址D又称为直接地址。此时,由寻址模式给予指示。 如果用 S表示操作数,那么直接寻址的逻辑表达式为 S=(E)=(D) 间接寻址:是相对于直接寻址而言的,在间接寻址的情况下,指令地址字段中 的形式地址D不是操作数的真正地址,而是操作数地址的指示器,或者说D单元 的内容才是操作数的有效地址。 如果把直接寻址和间接寻址结合起来,指令有如下形式: 操作码 I D 寻址特征位I=0,表示直接寻址,这时有效地址E=D;I=1,表示间接寻址, 这时有效地址E=(D)。 间接寻址方式是早期计算机中经常采用的方式,但由于两次访存,影响指令执 行速度,现在已不大使用。
[例4] 某16位机器所使用的指令格式和寻址方式如下所示,该机有 例 两个20位基址寄存器,四个16位变址寄存器,十六个16位通用寄 存器,指令汇编格式中的S(源),D(目标)都是通用寄存器, M是主存中的一个单元。三种指令的操作码分别是MOV(OP)= (A)H ,STA(OP)=(1B)H ,LDA(OP)=(3C)H。 MOV是传送指令,STA为写数指令,LDA为读数指令。
4.4 堆栈寻址方式
堆栈是一组能存储和取出数据的暂时存储单元。 堆栈和其他形式的存储器之间的差别就在于,它们对数据的存取方法或寻址方法有所不同。
4.4.1 串联堆栈
串行堆栈是由CPU当中的一组专门的寄存器构成。串行堆栈的最大优点是速度快。
4.4.2 存储器堆栈
串行堆栈存的容量有限,为了突破这种限制,使用了存储器堆栈,其优点在于: 堆栈能够具有程序员要求的任意长度; 只要程序员喜欢,愿意建立多少堆栈,就能建立多少堆栈; 可以用对存储器寻址的任何一条指令来对堆栈中的数据进行寻址。 存储器堆栈使用CPU中的一个特殊寄存器作为堆栈指示器。 串联堆栈和存储器堆栈的操作方式不同,在串联堆栈中,移动的是数据,而在存储器堆栈 中,移动的是栈顶。这主要和两种堆栈的速度有关。 堆栈两种操作:进栈 、出栈
4.3.2 操作数寻址方式
寄存器寻址方式和寄存器间接寻址方式:当操作数不放在内存中,而是 放在CPU的通用寄存器中时,可采用寄存器寻址方式。此时指令中给出的 操作数地址不是内存的地址单元号,而是通用寄存器的编号。 寄存器寻址方式和寄存器间接寻址方式的区别在于:指令中的寄存器内 容不是操作数,而是操作数的地址,该地址指明的操作数在内存中。 相对寻址:是把程序计数器PC的内容加上指令格式中的形式地址D而形成 操作数的有效地址。 程序计数器的内容就是当前指令的地址。“相对”寻址,就是相对于当 前的指令地址而言。 采用相对寻址方式的好处是程序员无须用指令的绝对地址编程,所编程 序可以放在内存任何地方。 此时形式地址D通常称为偏移量,其值可正 可负,相对于当前指令地址进行浮动。 基址寻址方式:将CPU中基址寄存器的内容加上指令格式中的形式地址而 形成操作数的有效地址。 它的优点是可以扩大寻址能力。同形式地址相比,基址寄存器的位数可 以设置得很长,从而可以在较大的存储空间中寻址。
[例3] 例 一种二地址RS型指令的结构如下所示: 6位 4位 1位 2位 16位 OP ---通用寄存器 I X 偏移量D 通用寄存器 偏移量 其中I为间接寻址标志位,X为寻址模式字段,D位偏移量字段。通 过I,X,D的组合,可构成下表所示的寻址方式。 请写出六种寻 址方式的名称。 有效地址E算法 寻址方式 I X 有效地址 算法 说明 (1) 0 00 E=D (2) 0 01 E=(PC)+D PC为程序计数器 为程序计数器 (3) 0 10 E=(R2)+D R2为变址寄存器 (4) 1 11 E=(R3) (5) 1 00 E=(D) (6) 0 11 E=(R1)+D R1为基址寄存器 [解]: 解 ⑴直接寻址 ⑵相对寻址 ⑶变址寻址 ⑷寄存器间接寻址 ⑸间接寻址 ⑹基址寻址
1. 顺序寻址方式
指令地址在内存中按顺序安排,当执行一段程序时,通常是一条指令接一 指令地址在内存中按顺序安排,当执行一段程序时, 条指令的顺序执行。 条指令的顺序执行。 为此,必须使用程序计数器(又称指令指针寄存器)PC来计数指令的顺序 为此,必须使用程序计数器(又称指令指针寄存器)PC来计数指令的顺序 该顺序号就是指令在内存中的地址。 号,该顺序号就是指令在内存中的地址。
4.3 指令和数据的寻址方式
操作数或指令在存储器中的地址: 操作数或指令在存储器中的地址:某个操作数或某条指令存放在某个存储单 元时其存储单元的编号。 元时其存储单元的编号。 在存储器中,操作数或指令写入或读出的方式,有三种:地址指定方式、 在存储器中,操作数或指令写入或读出的方式,有三种:地址指定方式、相 堆栈存储方式。 联存储方式和 堆栈存储方式。 当采用地址指定方式时,形成操作数或指令地址的方式,称为寻址方式 寻址方式。 当采用地址指定方式时,形成操作数或指令地址的方式,称为寻址方式。寻 址方式分为两类,即指令寻址方式和数据寻址方式。 址方式分为两类,即指令寻址方式和数据寻址方式。 指令的寻址方式有两种,一种是顺序寻址方式,另一种是跳跃寻址方式。 指令的寻址方式有两种,一种是顺序寻址方式,另一种是跳跃寻址方式。 4.3.1 指令的寻址方式
2. 跳跃寻址方式
当程序转移执行的顺序时,指令的寻址就采取跳跃寻址方式。所谓跳跃, 当程序转移执行的顺序时,指令的寻址就采取跳跃寻址方式。所谓跳跃,是 指下条指令的地址码不是由程序计数器给出,而是由本条指令给出。 指下条指令的地址码不是由程序计数器给出,而是由本条指令给出。程序跳 跃后,按新的指令地址开始顺序执行。 跃后,按新的指令地址开始顺序执行。
4.3.2 操作数寻址方式