【408精华知识】指令的寻址方式

在这里插入图片描述

文章目录

  • 一、指令寻址
    • (一)顺序寻址
    • (二)跳跃寻址
  • 二、数据寻址
    • (一)隐含寻址
    • (二)立即(数)寻址
    • (三)直接寻址
    • (四)间接寻址
    • (五)寄存器寻址
    • (六)寄存器间接寻址
    • (七)相对寻址
    • (八)基址寻址
    • (九)变址寻址
    • (十)堆栈寻址

寻址方式是指寻找指令或操作数有效地址的方式,即确定本条指令的数据地址及下一条待执行指令的地址的方法。寻址方式分为指令寻址和数据寻址两大类。

一、指令寻址

(一)顺序寻址

通过程序计数器PC加1(1条指令的长度),自动形成下一条指令的地址。

PC 自增的大小与编址方式、指令字长有关。现代计算机通常是按字节编址的,若指令字长为16位,则 PC自增为(PC)+2;若指令字长为32位,则PC自增为(PC)+4。

(二)跳跃寻址

通过转移类指令实现。跳跃是指由本条指令给出下条指令地址的计算方式。而是否跳跃可能受到状态寄存器的控制,跳跃的方式分为绝对转移(地址码直接指出转移目标地址)和相对转移(地址码指出转移目的地址相对于当前PC 值的偏移量),由于CPU总是根据PC的内容去主存取指令的,因此转移指令执行的结果是修改PC 值,下一条指令仍然通过PC 给出。

二、数据寻址

数据寻址是指如何在指令中表示一个操作数的地址,或怎样计算出操作数的地址。数据寻址的方式较多,为区别各种方式,通常在指令字中设置一个寻址特征字段,用来指明属于哪种寻址方式(其位数决定了寻址方式的种类),由此可得指令的格式如下所示:

操作码寻址特征形式地址A

一地址指令
在这里插入图片描述

二地址指令
在这里插入图片描述

指令中的地址码字段并不代表操作数的真实地址,这种地址称为形式地址,即A。形式地址结合寻址方式,可以计算出操作数在存储器中的真实地址,这种地址称为有效地址,即EA,(A)表示地址为A的数值,A既可以是寄存器编号,又可以是内存地址。

常见的寻址方式分为以下几种

寻址方式有效地址访存次数备注
隐含寻址程序指定0——
立即寻址A即是操作数0——
直接寻址EA=A1——
一次间接寻址EA=(A)2——
寄存器寻址EA=Ri0——
寄存器间接一次寻址EA=(Ri)1——
相对寻址EA=(PC)+ A1属于偏移寻址,用于指令转移
基址寻址EA=(BR)+ A1属于偏移寻址,用于多道程序
变址寻址EA=(IX)+ A1属于偏移寻址,用于循环程序

(一)隐含寻址

这种类型的指令,不是明显地给出操作数的地址,而是在指令中隐含着操作数的地址。例如单地址指令格式,就不给出第二操作数的地址,而是规定累加器ACC作为第二操作数的地址,指令中只是明显指出第一操作数。隐含寻址的优点是有利于缩短指令字长,缺点是需要增加存储操作数的硬件和存储隐含地址的硬件。
在这里插入图片描述

(二)立即(数)寻址

这种类型的指令的地址码字段指出的不是操作数的地址,而是操作数本身,又叫立即数。数据采用补码的形式存放。立即寻址的优点是指令在执行阶段不访问主存,指令执行的时间最短,缺点是A的位数限制了立即数的范围。(在定长指令码格式下,所有指令的长度都是一样的,这时候取每条指令的时间都一样,执行指令时立即数寻址最快,但是如果在变长指令码下,受到形式地址位数的限制,如果操作数比较大,那立即寻址方式在取指令的时间上要用时更多一点)

在这里插入图片描述

(三)直接寻址

这种类型的指令的地址码字段的形式地址就是操作数的真实地址,取数操作直接取地址里面的内容,它的有点是简单,只需要访问一次主存,不需要专门计算操作数的地址,缺点是A的位数决定了该指令操作数的寻址范围,操作数的地址不易修改,相对于立即寻址,直接寻址缩短了指令的长度。
在这里插入图片描述

(四)间接寻址

这种类型的指令是相对于直接寻址而来的,在直接寻址中,形式地址就是真实地址,在间接寻址中,形式地址是操作数地址的地址,即EA=(A),间接寻址可以是一次间接,也可以是多次间接。它的优点是可以扩大寻址范围,因为EA的位数大于A的位数,便于编制程序,可以方便地实现子程序的返回,缺点是在执行使需要多次访问内存,访问速度慢。这种寻址方式并不常用。一般扩大寻址范围都采用寄存器间接寻址。毕竟访问寄存器更快一点。
在这里插入图片描述
在这里插入图片描述

(五)寄存器寻址

这种类型的指令是直接给出操作数所在的寄存器的编号,EA=Ri,操作数就在Ri内存放。寄存器寻址的优点是指令在执行阶段不访问主存,只访问寄存器,因此执行速度快,因为寄存器数量少,所以寄存器编号所占的位数也少,指令字长也比较短。缺点是寄存价格昂贵,计算机中寄存器的个数也是有限的。
在这里插入图片描述

(六)寄存器间接寻址

这种类型的指令是相对于寄存器寻址的,指令中还是直接给出寄存器的编号,但是寄存器中存放的不是操作数而是操作数所在的地址,EA=(Ri)。它的优点是扩大了寻址范围,比间接寻址速度更快,但是指令执行阶段还是要访问主存的。
在这里插入图片描述

(七)相对寻址

这种类型的指令是将程序计数器PC中的内容与指令中的形式地址A相加,从而得出操作数的有效地址EA=(PC)+A,A是相对于当前指令地址的位移量,用补码表示。相对寻址的优点是,操作数的地址是不固定的,它随着PC值的变化而变化,并且与指令地址之间总是相差一个固定值,因此便于程序的浮动(随着操作系统功能的日渐强大,程序在主存中的位置不是固定不变的)。相对寻址用于控制程序的执行顺序、转移等。
在这里插入图片描述

(八)基址寻址

这种类型的指令是将CPU中基址寄存器BR的内容加上指令格式中的形式地址,形成操作数的真实地址,EA=(BR)+A。其中,基址寄存器既可以采用专用寄存器,也可以采用通用寄存器。
在这里插入图片描述
在这里插入图片描述

基址寄存器是面向操作系统的,它的内容由操作系统或管理程序确定,主要用于解决程序逻辑空间与存储器物理空间的无关性。程序运行过程中,基址寄存器中的内容是不变的,形式地址是可变的。如果采用通用寄存器作为基址寄存器,可以由用户决定哪个寄存器作为基址寄存器,但是内容还是由操作系统决定。

基址寻址的有点是可以扩大寻址范围(基址寄存器的位数大于A的位数),用户不用考虑自己的程序存放在主存的哪个区域,有利于多道程序设计,可用于编址浮动程序,常用于为程序和数据分配存储空间。

(九)变址寻址

这种类型的指令是将指令中的形式地址与变址寄存器IX内容相加,得到真实地址,EA=(IX)+A,也可以用通用寄存器作为变址寄存器。
在这里插入图片描述

与基址寻址相反,变址寻址是面向用户的,在程序执行的过程中,变址寄存器中的内容是可以由用户改变的,用作偏移量,而形式地址A则不变,作为基地址。

变址寻址的优点是可以扩大寻址范围(变址寄存器的位数大于A的位数),主要用在数组处理过程中,可以设定A为数组首地址,然后不断改变IX中的值即可形成数组中任意一个数据的地址,适合编制循环程序。IX的位数足以表示整个存储空间。

(十)堆栈寻址

堆栈是存储器中的一块按照后进先出原则管理的存储区,改存储区中被读/写单元的地址是由一个特定的寄存器给出的,该寄存器称为堆栈指针SP。堆栈可分为硬堆栈和软堆栈,硬堆栈是指寄存器堆栈,由于制作成本高,不适合做大容量,一般采用软堆栈,即从主存中划分出一段区域来作为堆栈。
在这里插入图片描述

在采用堆栈结构的计算机系统中,大部分指令表面上都表现为无操作数指令的形式,因为操作数地址都隐含了SP。通常在读或写堆栈中的一个单元的前后都伴有自动完成对SP内容的增减。

写在后面

这个专栏主要是我在学习408真题的过程中总结的一些笔记,因为我学的也很一般,如果有错误和不足之处,还望大家在评论区指出。希望能给大家的学习带来一点帮助,共同进步!!!

参考资料
[1]王道408教材(2025版)
[2]王道课程资料

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/331720.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

外卖系统源码开发全攻略:外卖小程序与后台管理系统的设计与实现

今天,小编将详细介绍外卖系统源码的开发全攻略,从需求分析到设计与实现,为开发者提供全面指导。 一、需求分析 1.用户需求 用户是外卖系统的核心,需满足以下基本需求: -浏览菜单并下单 -实时追踪订单 -多种支付方…

移动硬盘难题:不显示容量与无法访问的解决策略

在使用移动硬盘的过程中,有时会遇到一些棘手的问题,比如移动硬盘不显示容量且无法访问。这种情况让人十分头疼,因为它不仅影响了数据的正常使用,还可能导致重要数据的丢失。接下来,我们就来详细探讨一下这个问题及其解…

Python | Leetcode Python题解之第112题路径总和

题目: 题解: class Solution:def hasPathSum(self, root: TreeNode, sum: int) -> bool:if not root:return Falseif not root.left and not root.right:return sum root.valreturn self.hasPathSum(root.left, sum - root.val) or self.hasPathSum…

太狠了,凌晨5点面试。。

(关注数据结构和算法,了解更多新知识) 网上看到一网友发文说收到面试邀请,面试时间竟然是早晨5点,这是要猝死的节奏。有的网友说应该是下午 5 点,如果是下午 5 点直接写下午 5 点就行了,或者写 17 点也行,直…

Unity Assembly Definition Dotween 引用

原理: 具体Unity程序集原理用法,暂时留坑,不介绍了,相信有很多人也写过了 这里简单放个官方API链接 https://docs.unity3d.com/cn/current/Manual/ScriptCompilationAssemblyDefinitionFiles.html 现象 :Dotween引用…

捕捉二氧化碳也能赚钱?深入探索CCUS技术与商业前景

引言 随着全球变暖和气候变化的加剧,如何有效减少二氧化碳(CO2)排放成为各国亟待解决的问题。近日,全球最大的二氧化碳捕集工厂在冰岛正式运营,这一消息引起了广泛关注。本文将深入探讨捕集二氧化碳技术(C…

Java进阶学习笔记20——枚举

认识枚举: 枚举是一种特殊的类。 枚举类的格式: 说明: 第一行是罗列枚举的对象名称。只能写合法的标识符(名称),多个名称用逗号隔开。 这些名称本质上都是常量,每个变量都会记住枚举类的一个…

RobotFramework测试框架(13)--内置测试库

Builtln Evaluate方法 Evaluate。它可以做很多事情,主要的作用是可以直接调用Python的方法 一般用Evaluate都是前面放变量接收值,第三列是具体的运算表达式,第四列是要用到的Python的module。这里就是用random来进行一个随机数的生成 Cons…

python写接口性能测试

import time import requestsdef measure_response_time(api_url):try:start_time time.time()response requests.get(api_url, timeout10) # 设置超时时间为10秒end_time time.time()response_time end_time - start_timeprint(f"接口 {api_url} 的响应时间为&#…

nodeJs学习(第一周)

文章目录 学习总结nodejs基础知识核心模块(内置模块)fs(file-system)文件系统fs增删查改urlQuery String httprequest根据不同的请求路径发送不同的响应结果requireip地址和端口号Content-Type 第三方模块 express登录接口逻辑分析…

乡村振兴的乡村文化传承与活化:活化乡村传统文化,传承乡村文化基因,打造具有文化魅力的美丽乡村

目录 一、引言 二、乡村文化的独特价值与现状 三、活化乡村传统文化的策略 1、挖掘乡村文化资源 2、创新文化表达方式 3、加强文化产业发展 四、传承乡村文化基因的途径 1、加强文化教育 2、培育文化人才 3、弘扬文化精神 五、打造具有文化魅力的美丽乡村 1、规划乡…

Photoshop插件(UXP)编写过程中,如何更新sp-checkbox的选中状态

✨问题说明 sp-checkbox是uxpSpectrum UXP Widgets下的一个小组件&#xff0c;内置样式大概是这样&#xff1a; 那么&#xff0c;如果用js动态的改变选中的状态&#xff0c;应该如何做呢&#xff1f; 如果直接是html来写&#xff1a; <sp-checkbox checked>Checked<…

基于SpringBoot+Vue+Mysql的实验室低值易耗品管理系统

博主介绍&#xff1a; 大家好&#xff0c;本人精通Java、Python、C#、C、C编程语言&#xff0c;同时也熟练掌握微信小程序、Php和Android等技术&#xff0c;能够为大家提供全方位的技术支持和交流。 我有丰富的成品Java、Python、C#毕设项目经验&#xff0c;能够为学生提供各类…

求斐波那契数列第n项的值

本期介绍&#x1f356; 主要介绍&#xff1a;什么是斐波那契数列&#xff0c;递归实现求斐波那契数列第n项值&#xff0c;递归法为什么不适合求斐波那契数&#xff0c;用迭代法实现求斐波那契数列的值&#x1f440;。 文章目录 1. 斐波那契数列是什么&#xff1f;2. 题目2. 递归…

【Python 对接QQ的接口(二)】简单用接口查询【等级/昵称/头像/Q龄/当天在线时长/下一个等级升级需多少天】

文章日期&#xff1a;2024.05.25 使用工具&#xff1a;Python 类型&#xff1a;QQ接口 文章全程已做去敏处理&#xff01;&#xff01;&#xff01; 【需要做的可联系我】 AES解密处理&#xff08;直接解密即可&#xff09;&#xff08;crypto-js.js 标准算法&#xff09;&…

Android9.0 MTK平台如何增加一个系统应用

在安卓定制化开发过程中&#xff0c;难免遇到要把自己的app预置到系统中&#xff0c;作为系统应用使用&#xff0c;其实方法有很多&#xff0c;过程很简单&#xff0c;今天分享一下我是怎么做的&#xff0c;共总分两步&#xff1a; 第一步&#xff1a;要找到当前系统应用apk存…

Golang并发编程-协程goroutine的信道(channel)

文章目录 前言一、信道的定义与使用信道的声明信道的使用 二、信道的容量与长度三、缓冲信道与无缓冲信道缓冲信道无缓冲信道 四、信道的初体验信道关闭的广播机制 总结 前言 Goroutine的开发&#xff0c;当遇到生产者消费者场景的时候&#xff0c;离不开 channel&#xff08;…

关于XtremIO 全闪存储维护的一些坑(建议)

XtremIO 是EMC过去主推的一款全闪存储系统&#xff0c;号称性能小怪兽&#xff0c;对付那些对于性能要求极高的业务场景是比较合适的&#xff0c;先后推出了1代和2代产品&#xff0c;目前这个产品好像未来的演进到了PowerStor或者PowerMax全闪&#xff0c;应该不独立发展这个产…

存在重复元素 II[简单]

优质博文&#xff1a;IT-BLOG-CN 一、题目 给你一个整数数组nums和一个整数k&#xff0c;判断数组中是否存在两个不同的索引i和j&#xff0c;满足nums[i] nums[j]且abs(i - j) < k。如果存在&#xff0c;返回true&#xff1b;否则&#xff0c;返回false。 示例 1&#…

Excel工作簿/表的合并/拆分全集(一文通关)

概述 在工作中&#xff0c;我们常会用到到Excel拆分/合并为多个工作表/簿&#xff0c;如全国的订单表&#xff0c;需要根据省份列拆分下发至对应的省、各省份数据需要汇总、...... 应该如何操作呢&#xff1f; 1. 传统方法&#xff08;借助透视表、Power Query编辑器、VBA实现…