物理地址,虚拟地址,逻辑地址,线性地址概念

虚拟地址为进程提供隔离的内存视图,避免直接使用物理地址带来的管理问题。每个进程拥有独立的页表,通过内存管理单元MMU将线性地址转换为物理地址进行寻址。在虚拟内存出现之前,逻辑地址(基地址+段偏移)被用于提供轻量级的进程隔离,但安全性较低。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

文章目录


在使用DOS的时代,或现在使用单片机,内存以KB为单位,程序规模相对较小。这时候程序使用的是绝对地址,当需要操作内存时,CPU将程序提供的地址送到地址总线,再通过地址译码器,便可以定位到内存中的某个字节。这时候使用的地址,也是 物理地址,可以认为物理地址表示一个字节再RAM/ROM中电路布局,所定位的位置不会改变(当然在硬件配置不改变的前提下,了解过单片机的都知道,电路引脚换一换,物理地址所对应的内存就改变了)。

当内存逐渐变大,程序规模逐渐变大时候,这时候直接使用物理地址定位内存便会出现管理问题。如,多个进程可能互相覆盖彼此的数据,进程的数据或者代码可能被意外修改等。为解决这个问题,提出虚拟地址的概念,虚拟地址为各个进程提供一致的地址空间视图,即虚拟内存,由操作系统实行虚拟地址到物理地址间映射的职责,保证各个进程正常运行。

所以虚拟地址怎么为进程提供一致的地址空间视图呢?
进程运行在虚拟内存中,进程认为内存只被自己和内核独占,观察不到其他进程存在。在虚拟内存中,内存被划分为程序的代码段,数据段,堆栈段,以及被内核所使用的内核地址空间,如下图。

进程地址空间

现代操作系统通过虚拟内存为进程提供隔离方法。

这时候写个C程序,打印一个指针地址,该地址不是绝对的物理地址,而是虚拟地址,也叫做线性地址

那内核怎么通过虚拟地址寻址呢?
以4GB大小内存为例,内核将4GB内存按4KB大小分为1024 * 1024页,并通过两级页表管理这些分页,每个进程拥有各自独立页表。进程寻址时候,通过内存管理单元MMU,以及线性地址中的信息,转换为物理地址,再通过物理地址进行真正的寻址,如下图。内核保证没有多个页表项被意外映射为同一分页。

### 逻辑地址线性地址虚拟地址物理地址区别 #### 逻辑地址 逻辑地址也被称为有效地址或段内偏移地址,在任何CPU模式下都存在。它由程序产生的相对某个段寄存器的偏移量构成。例如,在实模式下的汇编指令 `mov ax, [0x7c00]` 中,`0x7c00` 就是一个逻辑地址[^3]。 #### 线性地址 当启用了分页机制时,线性地址作为从逻辑地址转换至物理地址过程中的过渡形式出现;而在未启用分页的情况下,则直接充当物理地址的角色。具体来说,线性地址是由逻辑地址(即段内的偏移地址)加上相应的段基址计算得出的结果。对于支持此特性的处理器架构而言,比如 Intel 80386 处理器家族成员所定义的最大可寻址范围可达4GB (2^32)[^2]。 #### 虚拟地址 在现代操作系统中广泛采用的一种抽象概念——虚拟地址实际上指的是应用程序视角下的线性地址。这意味着每个独立执行单元(如进程)都被赋予了一套统一而连续的地址区间供其自由支配,即使这些区域可能映射到了不相邻甚至散布于整个系统的不同部分的真实存储资源上。因此,借助这种间接层次的设计理念,软件开发者可以更加方便地编写代码而不必关心底层硬件细节[^4]。 #### 物理地址 最终被用来真正定位RAM芯片内部特定字节位置的信息便是所谓的物理地址。它是经过一系列复杂的变换流程之后得到的实际可用数值,用于指示具体的内存单元所在之处。只有在这个阶段,计算机才能确切知道要读取或写入的数据究竟位于哪里[^1]。 ```cpp // 示例:展示如何获取当前平台上的页面大小 #include <unistd.h> longpagesize=getpagesize(); printf("Page size:%ld\n",pagesize); ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值