操作系统 -- 虚拟内存

简介: 操作系统 -- 虚拟内存

虚拟内存


起因


程序规模的增加远大于存储容量的增长速度。


理想中的存储器:更大、更快、更便宜的非易失性存储器。


在计算机系统中,尤其是在多道程序运行环境下,可能会出现内存不够的情况,怎么办?


  • 如果是程序太大,超过了内存的容量,可以采用手动的覆盖技术,只需要把指令和数据保存在内存当中
  • 如果是程序太多超过了内存的容量,可以采用自动的交换技术,把暂时不能执行的程序送到外存中
  • 如果想要在有限容量的内存中,以更小的页的粒度为单位装入更多更大的程序,可以采用自动的虚拟存储技术


覆盖技术


  • 目标:是在比较小的可用内存中运行比较大的程序。常用于多道程序系统,与分区的存储管理配合使用


  • 原理:把程序按照其自身的逻辑结构,划分为若干个功能上相对独立的程序模块,把那些不会同时执行的模块共享同一块内存区域,按时间先后来运行


必要部分的代码和数据常驻内存

可选部分在其他程序模块中实现,平时存放在外存中,在需要的时候才装入内存;

不存在调用关系的模块,不必要同时装入到内存中,从而就可以相互覆盖,即这些模块公用一个分区


  • 缺点:

由程序员来把一个大的程序划分为若干个小的功能模块,并确定各个模块之间的覆盖关系,费时费力,增加了编程的复杂度

覆盖模块从外存装入内存实际上是以延长时间来获取空间节省


交换技术


  • 目标:多道程序在内存中时,让正在运行的程序获取更多的内存资源
  • 方法:可以将暂时不能运行的程序送到外村,从而获取空闲内存空间。操作系统把一个进程的整个地址空间内容保存到外存中,而将外存中的某个进程的地址空间读入到内存中,换入唤出内容的大小为整个程序的地址空间
  • 交换技术实现的几个问题


交换时机的确定:何时需要发生交换?只当内存空间不够或有不够的危险时换出

交换区的大小:必须足够大以存放所有的用户进程的所有内存映像的拷贝;必须能对这些内存映像进行直接存取

程序换入时候的重定位:换出后再换入的内存位置不一定在原来的位置上,最高采用动态地址映射的方法


  • 覆盖和交换的比较

覆盖只发生在那些互相之间没有调用关系的程序模块之间,因此程序员必须给出程序内的各个模块之间的逻辑覆盖结构。

交换技术是以在内存中的程序大小为单位来进行的,它不需要程序员给出各个模块之间的逻辑覆盖结构。换言之,交换发生在内存中程序与管理程序或操作系统之间,而覆盖则发生在运行程序的内部。


虚拟技术


  • 目标:


像覆盖技术一样,不是把程序的所有内容都放在内存中,因此能够运行比当前的空闲内存空间还要大的程序。但做的更好,由操作系统自动完成,无需程序员干涉。

像交换技术那样,能够实现进程在内存和外存之间的交换,因而获得更多的空闲内存空间,但是做的更好,只对进程部分内容在内存和外存之间进行交换。


  • 程序局部性原理:指的是程序在执行过程中的一个较短的时间内。所执行的指令地址和指令操作数地址,分别局限于一定区域


时间局部性:一条指令的一次执行和下次执行,一个数据的一次访问和下次访问都集中在一个较短的时期内

空间局部性:当前指令和邻近的几条指令,当前访问的数据和邻近的几个数据都几种在一个较小的区域内

程序局部性原理表明,从理论上来说,虚拟存储技术是能够实现的,而且在实现了以后应该是能够取得一个满意的效果的


  • 基本概念:可以在页式或者段式内存管理基础上实现


在装入程序时候,不必将其全部装入到内存中,只需要将当前需要执行的部分页面或者段装入到内存,就可以将程序开始执行

在程序执行过程中,如果需要执行的指令或者访问的数据尚未在内存,则由处理器通知操作系统将相应的页面或者段调入到内存,然后继续执行程序

另一方面,操作系统将内存中暂时不使用的页面或者段调出保存在外存上,从而腾出更多空闲空间存放将要装入的程序以及将要调入的页面或段


  • 基本特征:


大的用户空间:通过把物理内存和外存相结合,提供给用户的虚拟内存空间通常大于实际的物理内存,即实现了这两者的分离。如32位的虚拟地址理论上可以访问4GB,但是实际上内存是256M,但是硬盘大于4GB

部分交换:与交换技术相比较,虚拟存储的调入或者是调出是对部分虚拟地址空间进行的

不连续性:物理内存分配不连续,虚拟地址空间使用的不连续


  • 虚拟页式内存管理:


页式内存管理:页表完成逻辑页到物理页帧的映射

大部分的虚拟存储系统都是采用虚拟页式存储管理技术,即在也是存储管理的基础上增加请求调页和页面置换的功能

当一个用户需要调入内存运行时候,不是将该程序的所有页面都装入内存,而是只装入部分的页面,就可启动程序运行

在运行过程中,如果发现要运行的程序或要访问数据不在内存,则向系统发出缺页中断请求,系统再处理这个中断时,将外存中相应的页面调入内存,使得该程序能够继续运行


  • 后备存储


概念:


一个虚拟地址空间的页面可以被映射到一个文件中的某个位置

代码段:映射到可执行二进制文件

动态加载的共享程序段:映射到动态调用库文件

其他段:可能被映射到交换文件


在何处保存未被映射的页?


能够简单的识别在二级存储中的页

交换空间:特殊格式,用于存储未被映射的页面


目录
相关文章
|
1天前
|
算法
探索操作系统中的虚拟内存管理
【5月更文挑战第20天】 在现代操作系统中,虚拟内存管理是一项关键技术,它允许系统利用有限的物理内存资源满足多个进程的内存需求。本文将深入探讨虚拟内存的工作原理、页面置换算法以及它们如何影响系统性能。通过分析不同的内存分配策略和页面置换技术,我们将揭示操作系统如何平衡效率与资源利用率,从而优化整体的系统响应速度和稳定性。
|
3天前
|
算法 安全 程序员
深入理解操作系统的内存管理机制
【5月更文挑战第18天】 在现代计算领域,操作系统的内存管理是确保系统高效稳定运行的关键。本文将详细探讨操作系统内存管理的核心概念、技术及其实现细节。通过分析虚拟内存、物理内存、分页、分段以及内存分配策略等要素,我们揭示了操作系统如何优化内存使用,保证安全性和提供多任务支持。此外,文中还将评估现代操作系统面临的内存管理挑战,如碎片化、内存泄露和虚拟化技术的应用。
|
3天前
|
算法 程序员 内存技术
深入理解操作系统内存管理:原理与实践
【5月更文挑战第18天】 在现代计算机系统中,操作系统扮演着关键角色,其中内存管理作为其核心功能之一,保障了系统资源的高效利用和程序的顺利运行。本文旨在探讨操作系统内存管理的基本原理及其在实际中的应用,涉及物理内存的组织、虚拟内存技术的实现以及内存分配策略等关键技术点。通过分析不同内存管理机制的优势与局限,我们将对操作系统如何协调多任务环境下的内存使用有更深刻的认识。
|
3天前
|
存储 算法 安全
深入理解操作系统的虚拟内存管理
【5月更文挑战第18天】在现代操作系统中,虚拟内存管理是一项核心功能,它允许系统使用有限的物理内存来模拟出看似无限的地址空间。本文将详细探讨虚拟内存的基本概念、工作原理及其在操作系统中的应用。我们将从虚拟内存的定义出发,解析其背后的关键技术如分页、分段和请求调页机制,并讨论其在提高系统性能和安全性方面的重要性。通过具体示例和案例分析,本文旨在为读者提供一个清晰的虚拟内存管理知识框架。
|
3天前
|
算法
深入理解操作系统的内存管理
【5月更文挑战第18天】 在现代计算机系统中,操作系统扮演着至关重要的角色,尤其在内存管理方面。本文将深入探讨操作系统内存管理的核心原理与技术,包括虚拟内存、分页机制、以及内存分配策略等。通过对这些概念的细致剖析,读者将获得对操作系统如何处理内存申请、分配、回收和优化的深刻理解。文章不仅涉及理论解释,还将介绍一些实际案例,帮助读者将这些理论知识应用于实践。
|
3天前
|
存储 缓存 算法
探索现代操作系统中的虚拟内存管理
【5月更文挑战第18天】 在当代计算机系统中,虚拟内存技术是支撑大型应用程序与多任务环境的关键。通过抽象物理硬件细节,它允许每个运行的程序仿佛拥有独立的、连续的地址空间。本文深入分析了虚拟内存的核心机制,包括分页、分段和请求分页调度,并讨论了它们如何提升系统的稳定性、安全性及效率。同时,文章还探讨了虚拟内存带来的性能问题及其优化策略,如页面置换算法和缓存技术。
11 4
|
3天前
|
存储 缓存 算法
深入理解操作系统内存管理:原理与实践
【5月更文挑战第17天】 本文旨在探讨操作系统中的内存管理机制,通过分析其核心原理及提供实际应用场景,帮助读者深化对操作系统内存管理的认识。文章首先介绍内存管理的基础知识,然后详细阐述连续分配与非连续分配策略,接着讨论分页和分段机制,并探索虚拟内存技术如何使得内存管理更加高效。此外,文中还将涉及内存优化技巧以及现代操作系统中内存管理面临的挑战。
|
4天前
|
算法
深入理解操作系统的内存管理
【5月更文挑战第17天】 在现代计算机系统中,操作系统扮演着资源管理者的角色,其内存管理机制对于系统性能和稳定性至关重要。本文将探讨操作系统内存管理的关键技术,包括虚拟内存、分页、分段以及内存分配策略,旨在提供一个全面的视角来理解操作系统如何高效地管理有限的物理内存资源。通过对这些技术的剖析,我们可以更好地理解操作系统的内部工作原理,并评估不同内存管理策略对系统性能的影响。
|
4天前
|
存储 算法 程序员
操作系统(11)----内存管理5
操作系统(11)----内存管理
10 1
操作系统(11)----内存管理5
|
4天前
|
存储 缓存 算法
操作系统(11)----内存管理4
操作系统(11)----内存管理
12 0