数据寻址——偏移寻址

简介: 数据寻址——偏移寻址

偏移寻址


相对寻址、基址寻址、变址寻址都属于偏移寻址。



三种偏移地址区别:


但是他们之间还是有区别的,在于偏移的“起点”不一样


  • 基址寻址:以程序的起始存放地址作为“起点”


  • 变址寻址:程序员自己决定从哪里作为“起点”


  • 相对寻址:以程序计数器PC所指地址作为“起点”


基址寻址


基址寻址:将CPU中基址寄存器(BR)的内容加上指令格式中的形式地址A,而形成操作数的有效地址,即EA=(BR)+A。


下图是两种基址寄存器的构成方式:



问题:(b)要用几个bit指明寄存器?


根据通用寄存器总数判断


假如通用寄存器有八个,因为 23=8 在,用3个bit 就可以指明 0~7 共八个数


基址寻址的作用


优点


优点:便于程序“浮动”,方便实现多道程序并发运行


扩充一下哈:


优点:


  1. 可扩大寻址范围(基址寄存器的位数大于形式地址A的位数);


  1. 用户不必考虑自己的程序存于主存的哪一空间区域,故有利于多道程序设计;


  1. 可用于编制浮动程序(整个程序在内存里边的浮动) 。


如下图是对一个简单程序的基址寻址图解



注意:


基址寄存器是面向操作系统的,其内容由操作系统或管理程序确定。在程序执行过程中,基址寄存器的内容不变(作为基地址),形式地址可变(作为偏移量)。


当采用通用寄存器作为基址寄存器时,可由用户决定哪个寄存器作为基址寄存器,但其内容仍由操作系统确定。


变址寻址


变址寻址:有效地址EA等于指令字中的形式地址A与变址寄存器IX的内容相加之和,即EA= (IX)+A,其中IX可为变址寄存器(专用),也可用通用寄存器作为变址寄存器 。



注意:


变址寄存器是面向用户的,在程序执行过程中,变址寄存器的内容可由用户改变(IX作为偏移量),形式地址A不变(作为基地址) 。


  • 这里对比一下基址寄存器中BR与A的执行过程:


基址寻址中,BR保持不变作为基地址,A作为偏移量


变址寻址的作用


我们先探讨一个问题:


当我们在用高级语言进行编写循环语句的时候,我们看着是很简单的,就像下面的C语言循环语句。


for(int i=0; i<10; i++){
  sum += a[i];
}


但是再计算机中他是这个样子的,



那么是时候召唤变址寻址了!!!!!


在数组处理过程中,可设定A为数组的 首地址,不断改变 变址寄存器IX的内容,便可很容易形成数组中任一数据的地址,特别适合编制循环程序。


我们将上面的改成变址寻址就是下图这个样子



优点


在数组处理过程中,可设定A为数组的首地址,不断改变变址寄存器IX的内容,便可很容易形成数组中任一数据的地址,特别适合编制循环程序。


注意:


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


补充:基址&变址复合寻址


实际应用中往往需要多种寻址方式复合使用(可理解为复合函数)



相对寻址


相对寻址:把程序计数器PC的内容加上指令格式中的形式地址A而形成操作数的有效地址,即EA=(PC)+A,其中A是相对于PC所指地址的位移量,可正可负,补码表示 。



相对寻址的作用


我们在探讨一下:还是刚才的程序


想一下:如果代码越来越多,我们要挪动for循环的位置呢?只通过直接和变址寻址还能正确访问地址吗?



怎么解决这个问题呢?我么可以在此基础上+上PC值,就能正确访问了,如下图所示。



优点:


操作数的地址不是固定的,它随着PC值的变化而变化,并且与指令地址之间总是相差一个固定值,因此便于程序浮动(一段代码在程序内部的浮动)。


相对寻址广泛应用于转移指令


小结



*扩展:硬件如何实现数的“比较”


相关文章
|
2月前
请求分页给出逻辑地址,求对应的物理地址
请求分页内存管理中如何根据逻辑地址计算物理地址的过程,包括确定页号、计算偏移量,并将其转换为物理地址。
92 1
请求分页给出逻辑地址,求对应的物理地址
|
存储 索引
逻辑地址与物理地址的转换
最近一直在学8086,上课老师突然问了个这。对于问题“8086 CPU 能提供20位的地址信息,可直接对1M个存储单元进行访问,而CPU内部可用来提供地址信息的寄存器都是16位,那怎样用16位寄存器来实现20位地址寻址呢"明白了不少。
160 0
|
存储
逻辑地址和物理地址转换
逻辑地址和物理地址转换
|
7月前
|
存储 Linux 程序员
x86的内存寻址方式
在16位的8086时代,CPU为了能寻址超过16位地址能表示的最大空间(因为 8086 的地址线 20 位而数据线 16 位),引入了段寄存器。通过将内存空间划分为若干个段(段寄存器像 ds、cs、ss 这些寄存器用于存放段基址),然后采用段基地址+段内偏移的方式访问内存,这样能访问1MB的内存空间了。
按字寻址和按字节寻址以及内存编码、地址总线与数据总线的理解
按字寻址和按字节寻址以及内存编码、地址总线与数据总线的理解
195 0
|
存储
数据寻址——堆栈寻址
数据寻址——堆栈寻址
502 0
数据寻址——堆栈寻址
|
存储
指令系统——数据寻址
指令系统——数据寻址
193 0
指令系统——数据寻址
|
机器学习/深度学习 存储 Linux
内存为什么要分段? 分成多少种段? 段与段寄存器的区别?
内存为什么要分段? 分成多少种段? 段与段寄存器的区别?
汇编(二) 内存地址空间、寄存器、物理地址以及物理地址的计算
汇编、内存地址空间、寄存器、物理地址、物理地址的计算、汇编指令
4982 1
|
Linux C++ 调度