操作系统中逻辑地址和物理地址的区别

简介: 操作系统中逻辑地址和物理地址的区别

本文是关于操作系统中逻辑地址和物理地址之间的区别。计算机操作系统中的内存使用两种不同类型的地址。物理地址是内存的实际地址,如RAM,虚拟地址只是缓存和RAM之间的逻辑地址映射。


在操作系统中,每当我们谈论代码或其部分的地址或地址空间时,我们指的是该部分代码所在的内存位置。让我们通过一个现实生活中的异常来了解操作系统中的寻址。在现实生活中,我们的房子都有特定的地址,所以如果我们想去某个特定的人的地方,我们会记得他/她的房子的地址。操作系统中的地址也是如此。我们将数据存储在不同位置的内存中,并为它们分配不同的地址,以便我们将来可以使用存储它们的相同地址再次访问它们。在操作系统中,我们使用 32 位体系结构中的 32 位地址空间和0xFFFFFFFF形式的十六进制数,从 0x000000000xFFFFFFFF


在对地址以及为什么需要它们进行了快速讨论之后,我们现在将区分逻辑地址和物理地址。

1、逻辑地址简介

当我们谈论逻辑地址时,我们指的是CPU分配给每个进程的地址。正如我们已经讨论过的,一个进程在内存中所处的实际地址与进程认为它所处的地址是不一样的。这种地址映射基本上是在进程共享内存时所必需的,而不需要让进程知道它们彼此共享相同的内存空间。现在让我们来讨论逻辑地址。


每当 CPU 运行一个进程时,它都会为该进程分配一个特定的内存。下图简要说明了内存段在不同部分的划分,其中程序代码段位于低地址,栈位于高地址。

640.jpg

此分配的内存空间位于 CPU 为进程生成的虚拟地址(虚拟或逻辑地址),指示进程的代码、堆和堆栈部分将驻留的进程的内存空间。这个逻辑地址无疑与内存空间的实际地址不同。虚拟地址也称为指向主存储器中实际或物理地址的引用或指针。


大多数操作系统在其程序中都定义了基地址,在生成逻辑地址时,CPU 生成一个地址,程序将基地址与 CPU 生成的地址相加得到逻辑地址,即


逻辑地址 = 基地址 + CPU 生成地址


一个逻辑地址空间是指CPU产生的所有逻辑地址的集合。

2、物理地址简介

物理地址是进程及其内容放置在主内存或硬盘中的地址。每当我们运行一个进程或将一些数据存储在计算机的主存储设备或辅助存储设备中时,我们总是将其存储起来以备将来随时访问。比如我在电脑的D盘存了一个word文件,我想访问它,以后怎么访问?当然是去D盘打开word文件。但是如果我将一个进程保存在主存中的某个存储单元或内存单元中,并希望将来访问它,该怎么办。就我们在本教程中研究过的地址而言,我们知道每当一个进程被创建时,CPU 都会生成它的虚拟地址,但又是一团糟。虚拟地址与进程实际放置在内存中的地址不同。


然而,内存单元存储在由物理地址(用户未知)访问的主内存中,我们所知道的只是进程的逻辑地址。那么当我们需要访问进程的时候我们将如何访问物理地址呢?到目前为止,这似乎是不可能的,但这当然不是因为我们从计算机诞生到现在一直在访问创建的进程。


因此,我们需要详细讨论这个问题。在进程创建时,CPU 不仅会生成虚拟地址,还会使用一些硬件支持将(先前生成的)虚拟地址映射到实际存储它的物理地址,这在下面的地址映射部分进行了讨论。因此,当我们尝试访问内存中已经保存的进程时,CPU 将虚拟地址返回给硬件,硬件将虚拟/逻辑地址映射到物理地址上,并间接访问进程的内存空间。

2.1、地址映射

现在让我们讨论硬件如何在逻辑地址和物理地址之间执行映射。在CPU和内存管理单元(MMU)的硬件中安装有助于地址的映射。下图很好的解释了。


640.png

这个内存管理单元对逻辑地址上的物理地址执行所有必需的映射。由MMU执行的非常基本的映射是由一种称为界限和基址的方案执行的。这是执行映射可以使用的最简单的方法。随着地址的映射变得越来越复杂,我们需要向内存管理单元添加越来越多的硬件。让我们讨论基址寄存器和界限寄存器。

2.2、基址和界限法

640.png

在基于界限和基址的方法中,每个 MMU 单元都有两个寄存器,称为基址寄存器和界限寄存器。基址寄存器中包含特定进程(正在运行)的内存部分的起始地址。例如,当硬件需要取一些指令时,首先需要将基址寄存器的值与逻辑地址相加,得到物理地址。因此,基址寄存器与访问内存有关,另一方面,界限寄存器要么存储特定进程的内存部分的结束地址,要么还可能包含内存部分的总大小(包括代码、堆栈和堆)。它仅用于保护,以便进程不超过分配给它的内存区域,并且它可能不会跳入另一个进程的内存区域。下面给出了逻辑地址和物理地址的一般比较。


物理地址 逻辑地址
定义 物理内存地址 虚拟地址
空间 内存空间所在的实际内存地址 引用物理地址/实际地址,称为逻辑地址空间
可见性 只对开发人员可见,对程序员不可见 只对用户可见
访问 用户在任何情况下都无法访问 用户可以轻松访问
生成 由 CPU 生成 由 MMU 生成

3、文献引用

[1] Yuvayana. (2020, August 13). What Is Memory Management Unit (MMU)?

https://er.yuvayana.org/what-is-memory-management-unit-mmu/

[2] Colin walls, & Dimitrios serpanos. (2012). Memory Management Unit.

https://www.sciencedirect.com/topics/computer-science/memory-management-unit

往期精

STM32系统bootloader应用


GitHub上最励志的计算机自学教程


"结构体"和"共用体"在单片机中的妙用


STM32硬核DIY机械键盘|蓝牙USB双模|灯控

目录
相关文章
|
5天前
|
安全 Android开发 数据安全/隐私保护
请说明鸿蒙操作系统与其他操作系统(如Android和iOS)的主要区别。
请说明鸿蒙操作系统与其他操作系统(如Android和iOS)的主要区别。
67 1
|
5天前
|
弹性计算 运维 安全
阿里云服务器Windows和Linux操作系统区别对比
阿里云服务器Windows和Linux操作系统区别对比,性能有差异吗?有,同配置下Linux性能要优于Windows,但这与阿里云无关,仅仅是linux和windows之间的区别。另外,阿里云提供的windows和linux操作系统均为正版授权,用户不需要额外支付许可费用,如何选择?看用户自己的应用程序情况。
|
5天前
|
安全 Java Linux
手机操作系统和嵌入式操作系统的区别和联系
手机操作系统和嵌入式操作系统的区别和联系
14 2
|
5天前
|
存储 算法 内存技术
深入理解操作系统内存管理:从虚拟内存到物理内存的映射
【4月更文挑战第30天】 在现代操作系统中,内存管理是一个复杂而关键的功能。它不仅确保了系统资源的有效利用,还为每个运行的程序提供了独立的地址空间,保障了程序之间的隔离性和安全性。本文将探讨操作系统如何通过分页机制和虚拟内存技术实现内存的抽象化,以及这些技术是如何影响应用程序性能的。我们将详细解析虚拟地址到物理地址的转换过程,并讨论操作系统在此过程中扮演的角色。文章的目的是为读者提供一个清晰的框架,以便更好地理解内存管理的工作原理及其对系统稳定性和效率的影响。
|
5天前
|
人工智能 缓存 算法
深入理解操作系统内存管理:从虚拟内存到物理内存的映射
【4月更文挑战第8天】 在现代操作系统中,内存管理是核心功能之一,它负责协调和管理计算机的内存资源,确保系统稳定高效地运行。本文深入探讨了操作系统内存管理的关键概念——虚拟内存和物理内存的映射机制。通过剖析分页系统、分段机制和虚拟内存地址转换过程,文章旨在为读者提供一个清晰的理解框架,同时讨论了内存管理的优化技术及其对系统性能的影响。此外,还简要介绍了内存碎片问题以及垃圾回收机制的重要性,并展望了未来内存管理技术的发展趋势。
|
5天前
|
存储 算法 内存技术
深入理解操作系统内存管理:从虚拟内存到物理内存
【2月更文挑战第30天】 在现代计算机系统中,操作系统的内存管理是确保系统高效稳定运行的关键组成部分。本文将深入探讨操作系统内存管理的复杂世界,特别是虚拟内存和物理内存之间的关联与转换机制。通过分析分页系统的工作原理、虚拟地址空间的结构以及页面置换算法,文章旨在为读者提供一个清晰的框架,以理解内存管理在操作系统中的重要性和实现细节。
|
5天前
|
存储 缓存 Linux
|
5天前
|
运维 安全 Linux
使用阿里云搭建幻兽帕鲁服务器操作系统类型Windows和Linux有区别吗?
使用阿里云搭建幻兽帕鲁服务器操作系统类型Windows和Linux有区别吗?性能有差异?同配置的游戏服务器,如4核16G或8核32G配置等,选择Windows和Linux操作系统差异不太大,如果非要对比的话,Linux系统相对Windows更少占用计算资源,当然如果对Linux不熟悉的话,可以选择Windows。另外,即便是幻兽帕鲁服务器创建成功后,也是可以免费修改操作系统的
121 1
|
6月前
|
存储 算法 Java
深入理解操作系统中进程与线程的区别及切换机制(下)
本文首先介绍了进程的控制结构,即进程控制块(PCB),它是表示进程的数据结构,包含了进程的相关信息和资源。PCB之间通过链表连接,形成就绪队列和阻塞队列,用于进程调度和资源管理。接着,文章详细探讨了进程的切换过程。进程切换是为了保证公平分配CPU时间片,涉及保存和恢复进程的执行上下文、更新进程状态和调度算法选择等步骤。文中还提到了进程上下文切换的场景,如时间片用完、内存不足、高优先级进程需求等。最后,文章介绍了线程的概念和上下文切换过程。线程是进程中的独立执行流程,可以共享进程的资源。线程的上下文切换开销较小,只需要保存和恢复线程的寄存器和计数器等信息。
深入理解操作系统中进程与线程的区别及切换机制(下)
|
6月前
|
Java 调度
深入理解操作系统中进程与线程的区别及切换机制(上)
进程是正在运行的程序的实例,它可以包含一个或多个线程。我们了解了进程的执行方式,包括早期单核处理器上的顺序执行以及引入多任务概念实现的伪并行。我们还探讨了进程的状态模型。进程可以处于就绪、运行、阻塞和结束等不同的状态。就绪状态表示进程已经准备好运行,但还没有被调度执行。运行状态表示进程正在执行。阻塞状态表示进程被阻塞,需要等待某些事件的发生才能继续执行。结束状态表示进程已经完成执行。
深入理解操作系统中进程与线程的区别及切换机制(上)

热门文章

最新文章