地址重定位

编辑:蛋黄网互动百科 时间:2020-04-08 17:04:04
编辑 锁定
本词条缺少名片图,补充相关内容使词条更完整,还能快速升级,赶紧来编辑吧!
内存地址的集合称为内存空间或物理地址空间。内存中,每一个存储单元都与相应的内存地址的编号相对应,显然,内存空间是一维线性的。
怎样把几个虚存的一维线性空间或多维线性空间变换到内存的唯一的一维物理线性空间?这涉及到两个问题:一个是虚拟空间的划分问题,另一个就是把虚拟空间中已经链接和划分好的内容装入内存,并将虚拟地址映射为内存地址的问题,称之为地址重定位地址映射
中文名
地址重定位

地址重定位地址重定位的分类:

编辑
地址重定位[1]  分为两种:静态地址重定位和动态地址重定位。

地址重定位静态地址重定位:

静态地址重定位是在虚拟空间程序执行之前,由装配程序完成的地址映射工作。对于虚拟空间内的指令和数据来说,静态地址重定位只完成了一个首地址不同的连续地址变换。它要求所有待执行的程序必须在程序执行之前完成它们之间的链接,否者将无法得到正确的内存地址和内存空间。
静态地址重定位的优点是不需要硬件支持,但是缺点是必须占有连续的内存空间,这就难以做到数据和程序的共享。

地址重定位动态地址重定位:

动态地址重定位是程序在执行过程中,在CPU访问内存之前,将要访问的程序或数据地址转换为内存地址。动态地址重定位需要硬件的支持。
地址重定位机构需要一个或多个基地址寄存器BR和一个或多个程序虚拟地址寄存器VR,指令或数据的内存地址MA与虚拟地址的计算关系如下:MA=(BR)+(VR),这里的(BR),(VR)分别表示寄存器中的内容。
动态重定位的优点有:内存可以不连续分配、提供实现虚存的基础、有利于程序共享。
参考资料
  • 1.    张尧学、史美林、张高.计算机操作系统教程.北京:清华大学出版社,2006年10月第三版:110页
词条标签:
计算机学