第一章 计算机硬件基础(寻址方式)

2024-03-15 21:04

本文主要是介绍第一章 计算机硬件基础(寻址方式),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

程序运行时用到的数据绝大部分存放在内存中,如何寻找内存中的数据就是存储器寻址方式。操作数在存储器中,操作数的有效地址EA在指令中,段地址在默认的或段超越前缀指定的段寄存器中。
例如:内存好比一栋大学宿舍楼,每个宿舍都住着人。
寻址的目的是找到数据,(通俗理解为你需要你去宿舍楼喊人)

1、立即寻址方式

指令中在操作码字段后面的部分不是通常意义上的操作数地址,而是操作数本身。地址码就是操作数,这样的寻址方式不必再次访问主存去取操作数,当然也无须改动操作数。立即寻址是获取操作数最快的方式。

操作数包含在指令中,紧跟着操作码并与操作码一起存放在代码段中,与代码一起被取入CPU的指令队列,指令执行时不需要再访问存储器。
立即寻址中的操作数可以是计算机有效数制下的数值,也可以是带单引号的字符。
例如: MOV      AX,3102H ;
            MOV       AL,‘A’ ;

 形式地址A就是操作数

指令执行阶段不访存

A的位数限制了立即数的范围

2、直接寻址方式

指令的地址码就是操作数在主存内的地址,也就是说地址码就是主存内数据的绝对地址,不必做不论什么换算,只要按照地址码去主存中找,但这样的地址方式的不足之处在于寻址范围有限(只在一个存储器中)。

在指令中直接给出操作数所在单元的位移地址,具体有两种形式。
(1) MOV   AX,[2050H] ;解释:默认的段寄存器为DS,AX←[DS×16+2050H]
位移地址通常以变量的形式出现,在指令中就直接写变量的名字
(2) MOV   SI , BUF; 解释:BUF为一变量,AX←[DS×16+BUF]
默认的段寄存器为DS,但也可以显式地指定其他段寄存器。称为“段超越”前缀。
例如:
MOV    DX,ES:[2050H];使用段超越;DX←[ES×16+2050H]

EA=A(有效地址由形式地址直接给出)

A 的位数决定了该指令操作数的寻址范围

操作数的地址不易修改(必须修改A)

3、间接寻址方式

在指令的地址码部分直接给出的既不是操作数(直接给出操作数的是立即寻址),也不是操作数的地址(直接给出操作数地址的是直接寻址),而是操作数的地址的地址

这样的方式提高了寻址的灵活性。扩大了寻址的范围。可是因为多次访问主存。速度大为减少。

EA=(A)

执行指令阶段2次访存

可扩大寻址范围

便于编制程序

4、寄存器(直接)寻址方式

地址码的地址不是操作数或地址,而是通用寄存器的编号,操作数在指定编号的寄存器里。(可以是8位也可以是16位(AX,BX,CX,DX)),寄存器中存着操作数,如:MOV DS,AX。访问寄存器的速度是很快的,所以使用寄存器寻址有很快的速度。(不足之处在于寄存器的数量有限)

EA=Ri,有效地址即为寄存器编号

执行阶段不访存,之访问寄存器,执行速度快

寄存器个数有限,可缩短指令字长

5、寄存器间接寻址方式

寄存器间接寻址也是指定寄存器编号,但是寄存器内存放的并不是操作数,而是操作数的有效地址。有效地址在寄存器中,操作数在存储器中,执行阶段访存,但访存比间接寻址少一次,便于编制循环程序(这是与寄存器寻址的区别)。这样既快又有灵活性,是一种广泛使用的寻址方式。

EA=(Ri)

有效地址在寄存器中,操作数在存储器中,执行阶段访存。

便于编制循环程序。

6、相对寻址方式

相对寻址和变址寻址类似,这里变址寄存器变成了程序计数器,也就是在相对寻址中是将地址码和程序计数器内容相加后形成的数据地址。

相对寻址最大的特点就是转移地址不固定,他随PC值的变化而变化,因此,无论主程序在哪段区域,都可正常运行,对编写浮动程序特别有利。

 A的位数决定操作数的寻址范围

程序浮动

广泛用于转移指令

7、基址寻址方式

基址寻址需要有基址寄存器BR,操作数的有效地址等于形式地址加上基址寄存器中的内容(基地址)。基址寻址中的BR由系统或者管理程序根据主存的使用情况分配初始值,便可将用户程序的逻辑地址转化为主存的物理地址(实际地址)。

基址寄存器分为隐式和显式。隐式是指计算机内设有一个专门的,用户不必明显指出该基址寄存器,只需由寻址特征位反应基址寻址就可以。而显式是在一组通用寄存器内由用户指定一个基址寄存器存放基地址。

基址寻址的优点是可以扩大寻址能力,因为与形式地址相比,基址寄存器的位数可以设置得很长,从而可以在较大的存储空间中寻址。

(1)采用专用寄存器作基址寄存器    

  EA=(BR)+A  ,BR为基址存储器

可扩大寻址范围

有利于多道程序

BR内容由操作系统或管理程序确定

在程序的执行过程中BR内容不变,形式地址A可变

(2)采用通用寄存器作基址寄存器

 由用户指定哪个通用寄存器作为基址寄存器

基址寄存器的内容由操作系统确定

在程序的执行过程中R0内容不变,形式地址A可变

8、变址寻址方式

是将地址码和变址寄存器内容相加后形成的操作数有效地址,对数组运算、字符串操作等批量数据的处理很有效。

基址寻址主要用于为程序或数据分配内存空间,故基址寄存器的内容通常由操作系统或管理程序确定,在程序的执行过程中其值是不可变的,而指令字中的形式地址A是可变的,在变址寻址中,变址寄存器的内容是用户设定的,在程序执行过程中其值可变,而指令字中的A是不可变的。

变址寻址主要用于处理数组问题,在数组处理过程中,可设定A为数组的首地址,不断改变变址寄存器的IX内的内容,便可以得到数组中任一数据中的地址,特别适合编制循环程序。

 EA=(IX)+A,IX为变址寄存器(专用),通用寄存器也可以作为变址寄存器

可扩大寻址范围

IX的内容由用户给定

在程序的执行过程中IX内容可变,形式地址A不变

便于处理数组问题

这篇关于第一章 计算机硬件基础(寻址方式)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/813257

相关文章

Java AOP面向切面编程的概念和实现方式

《JavaAOP面向切面编程的概念和实现方式》AOP是面向切面编程,通过动态代理将横切关注点(如日志、事务)与核心业务逻辑分离,提升代码复用性和可维护性,本文给大家介绍JavaAOP面向切面编程的概... 目录一、AOP 是什么?二、AOP 的核心概念与实现方式核心概念实现方式三、Spring AOP 的关

从基础到高级详解Go语言中错误处理的实践指南

《从基础到高级详解Go语言中错误处理的实践指南》Go语言采用了一种独特而明确的错误处理哲学,与其他主流编程语言形成鲜明对比,本文将为大家详细介绍Go语言中错误处理详细方法,希望对大家有所帮助... 目录1 Go 错误处理哲学与核心机制1.1 错误接口设计1.2 错误与异常的区别2 错误创建与检查2.1 基础

Linux挂载linux/Windows共享目录实现方式

《Linux挂载linux/Windows共享目录实现方式》:本文主要介绍Linux挂载linux/Windows共享目录实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录文件共享协议linux环境作为服务端(NFS)在服务器端安装 NFS创建要共享的目录修改 NFS 配

Vue3视频播放组件 vue3-video-play使用方式

《Vue3视频播放组件vue3-video-play使用方式》vue3-video-play是Vue3的视频播放组件,基于原生video标签开发,支持MP4和HLS流,提供全局/局部引入方式,可监听... 目录一、安装二、全局引入三、局部引入四、基本使用五、事件监听六、播放 HLS 流七、更多功能总结在 v

Java发送SNMP至交换机获取交换机状态实现方式

《Java发送SNMP至交换机获取交换机状态实现方式》文章介绍使用SNMP4J库(2.7.0)通过RCF1213-MIB协议获取交换机单/多路状态,需开启SNMP支持,重点对比SNMPv1、v2c、v... 目录交换机协议SNMP库获取交换机单路状态获取交换机多路状态总结交换机协议这里使用的交换机协议为常

Spring的基础事务注解@Transactional作用解读

《Spring的基础事务注解@Transactional作用解读》文章介绍了Spring框架中的事务管理,核心注解@Transactional用于声明事务,支持传播机制、隔离级别等配置,结合@Tran... 目录一、事务管理基础1.1 Spring事务的核心注解1.2 注解属性详解1.3 实现原理二、事务事

k8s admin用户生成token方式

《k8sadmin用户生成token方式》用户使用Kubernetes1.28创建admin命名空间并部署,通过ClusterRoleBinding为jenkins用户授权集群级权限,生成并获取其t... 目录k8s admin用户生成token创建一个admin的命名空间查看k8s namespace 的

uni-app小程序项目中实现前端图片压缩实现方式(附详细代码)

《uni-app小程序项目中实现前端图片压缩实现方式(附详细代码)》在uni-app开发中,文件上传和图片处理是很常见的需求,但也经常会遇到各种问题,下面:本文主要介绍uni-app小程序项目中实... 目录方式一:使用<canvas>实现图片压缩(推荐,兼容性好)示例代码(小程序平台):方式二:使用uni

Pandas处理缺失数据的方式汇总

《Pandas处理缺失数据的方式汇总》许多教程中的数据与现实世界中的数据有很大不同,现实世界中的数据很少是干净且同质的,本文我们将讨论处理缺失数据的一些常规注意事项,了解Pandas如何表示缺失数据,... 目录缺失数据约定的权衡Pandas 中的缺失数据None 作为哨兵值NaN:缺失的数值数据Panda

java读取excel文件为base64实现方式

《java读取excel文件为base64实现方式》文章介绍使用ApachePOI和EasyExcel处理Excel文件并转换为Base64的方法,强调EasyExcel适合大文件且内存占用低,需注意... 目录使用 Apache POI 读取 Excel 并转换为 Base64使用 EasyExcel 处