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

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

相关文章

Jsoncpp的安装与使用方式

《Jsoncpp的安装与使用方式》JsonCpp是一个用于解析和生成JSON数据的C++库,它支持解析JSON文件或字符串到C++对象,以及将C++对象序列化回JSON格式,安装JsonCpp可以通过... 目录安装jsoncppJsoncpp的使用Value类构造函数检测保存的数据类型提取数据对json数

Redis事务与数据持久化方式

《Redis事务与数据持久化方式》该文档主要介绍了Redis事务和持久化机制,事务通过将多个命令打包执行,而持久化则通过快照(RDB)和追加式文件(AOF)两种方式将内存数据保存到磁盘,以防止数据丢失... 目录一、Redis 事务1.1 事务本质1.2 数据库事务与redis事务1.2.1 数据库事务1.

Linux磁盘分区、格式化和挂载方式

《Linux磁盘分区、格式化和挂载方式》本文详细介绍了Linux系统中磁盘分区、格式化和挂载的基本操作步骤和命令,包括MBR和GPT分区表的区别、fdisk和gdisk命令的使用、常见的文件系统格式以... 目录一、磁盘分区表分类二、fdisk命令创建分区1、交互式的命令2、分区主分区3、创建扩展分区,然后

Linux中chmod权限设置方式

《Linux中chmod权限设置方式》本文介绍了Linux系统中文件和目录权限的设置方法,包括chmod、chown和chgrp命令的使用,以及权限模式和符号模式的详细说明,通过这些命令,用户可以灵活... 目录设置基本权限命令:chmod1、权限介绍2、chmod命令常见用法和示例3、文件权限详解4、ch

Java中的密码加密方式

《Java中的密码加密方式》文章介绍了Java中使用MD5算法对密码进行加密的方法,以及如何通过加盐和多重加密来提高密码的安全性,MD5是一种不可逆的哈希算法,适合用于存储密码,因为其输出的摘要长度固... 目录Java的密码加密方式密码加密一般的应用方式是总结Java的密码加密方式密码加密【这里采用的

Java中ArrayList的8种浅拷贝方式示例代码

《Java中ArrayList的8种浅拷贝方式示例代码》:本文主要介绍Java中ArrayList的8种浅拷贝方式的相关资料,讲解了Java中ArrayList的浅拷贝概念,并详细分享了八种实现浅... 目录引言什么是浅拷贝?ArrayList 浅拷贝的重要性方法一:使用构造函数方法二:使用 addAll(

Mycat搭建分库分表方式

《Mycat搭建分库分表方式》文章介绍了如何使用分库分表架构来解决单表数据量过大带来的性能和存储容量限制的问题,通过在一对主从复制节点上配置数据源,并使用分片算法将数据分配到不同的数据库表中,可以有效... 目录分库分表解决的问题分库分表架构添加数据验证结果 总结分库分表解决的问题单表数据量过大带来的性能

SpringBoot项目引入token设置方式

《SpringBoot项目引入token设置方式》本文详细介绍了JWT(JSONWebToken)的基本概念、结构、应用场景以及工作原理,通过动手实践,展示了如何在SpringBoot项目中实现JWT... 目录一. 先了解熟悉JWT(jsON Web Token)1. JSON Web Token是什么鬼

在C#中合并和解析相对路径方式

《在C#中合并和解析相对路径方式》Path类提供了几个用于操作文件路径的静态方法,其中包括Combine方法和GetFullPath方法,Combine方法将两个路径合并在一起,但不会解析包含相对元素... 目录C#合并和解析相对路径System.IO.Path类幸运的是总结C#合并和解析相对路径对于 C

C语言线程池的常见实现方式详解

《C语言线程池的常见实现方式详解》本文介绍了如何使用C语言实现一个基本的线程池,线程池的实现包括工作线程、任务队列、任务调度、线程池的初始化、任务添加、销毁等步骤,感兴趣的朋友跟随小编一起看看吧... 目录1. 线程池的基本结构2. 线程池的实现步骤3. 线程池的核心数据结构4. 线程池的详细实现4.1 初