操作系统基础:虚拟内存【上】

简介: 操作系统基础:虚拟内存【上】



🐹1 虚拟内存的基本概念

🦓1.1 总览

🦓1.2 传统存储管理方式的缺点

🦓1.3 局部性原理

🦓1.4 虚拟内存

🦝1.4.1 定义

🦝1.4.2 特征

🦓1.5 如何实现虚拟内存

🦝1.5.1 需要解决的两个问题

(1)

此时操作系统需要提供请求调页(请求调段)功能

(2)

此时操作系统需要提供页面置换(段置换功能)

🦝1.5.2 常采用的技术

🦓1.6 总结

🐹2 请求分页管理方法

🦌2.1 总览

🦌2.2 页表机制

🦝2.2.1 需考虑的问题

为了实现虚拟内存的请求调页和页面置换功能,我们需要考虑以下问题

🦝2.2.2 页表的基本结构

访问字段:优先将访问次数较少的内存块调出内存

修改位:在将内存块调出内存时,对于已经修改过的内存块,需要将修改内容重新写入外存。

其他字段较为简单不再赘述

🦌2.3 缺页中断机制

🦝2.3.1 什么是缺页中断机制

🦝2.3.2 过程

🦌2.4 地址变换机制

🦝2.4.1 过程

与普通页表的地址变化过程类似。注意此处是引入了快表的

当发生缺页中断时,需要进行的护处理如下:

🦝2.4.2 补充细节

与上图中标注的序号匹配。

🦌2.5 总结

🐹3 页面置换算法

🐯3.1 总览

🐯3.2 最佳置换算法(OPT)

🐶3.2.1 算法思想

🐶3.2.2 例子

首先,页面会逐渐先将内存填满,如图所示

接着,进程需要2号页面,但是内存中没有,于是发生缺页中断。剩余的页面号引用串为0304230321201701,而内存中已经存在的页面为701,于是操作系统依次对页面进行查找,确定701中最后一个在页面号引用串中出现的数字,容易得到为7,于是将7号页面换出,将2号页面换入。

🐶3.2.3 缺点

(1)是一种理想算法

(2)注意

🐯3.3 先进先出置换算法(FIFO)

🐶3.3.1 算法思想

🐶3.3.2 例子

首先,页面会逐渐将内存填满,如图

接着,系统需要访问0号页面,但内存中没有,于是发生缺页异常。此时的页面队列为3 <- 2 <- 1,3是最先进去的,所以系统将3替换为0。

🐶3.3.3 缺点

🐯3.4 最近最久未使用置换算法(LRU)

🐶3.4.1 算法思想

🐶3.4.2 例子

假如系统的内存块数量为4,且会访问的页面串为:

1,8,1,7,8,2,3

首先,页面会逐渐将内存块填满,如图:

接着,系统访问7号页面,发现内存中没有,于是发生缺页异常,此时我们可以发现现有的页面1872中,它们的自上次被访问以来所经历的时间依次为3、2、1、0。所以系统将1号页面换出,换为3号页面。

我们在做题时,也可以逆序查找。比如此处内存中的页面为1872,而它们的逆序页面号为2、8、7、1,所以1是最久没有使用的,可以将其替换。

🐶3.4.3 缺点

它的效率最接近最佳替换算法,但是:

🐯3.5 时钟置换算法

🐶3.5.1 算法思想

访问位示意图:

🐶3.5.2 例子

因为进程有5个内存块,所以页面的循环队列的长度应该是5。初始时13425会依次填满内存块(这五个页面都被访问,于是它们的访问位都置为1),当访问到6号页面时,操作系统发现缺页,于是产生缺页异常,此时的循环队列为(1->3->4->2->5->1)。操作系统首先从队列的开头(1)寻找最近没有被访问的页面,直至查找到5,所有的页面都被访问过,于是按照时钟置换算法将所有页面的访问位都置为0,并再次开始寻找,此时第一个为0的页面是1,于是操作系统将1号页面换出,换入6号页面。

🐯3.6 改进型的时钟置换算法

🐶3.6.1 算法思想

🐶3.6.2 算法实现方法

🐶3.6.3 例子

(1)只需一轮扫描:

(2)需要两轮扫描:

(3)需要三轮扫描

(4)需要四轮扫描

🐶3.6.4 对算法的进一步理解

🐯3.7 总结

🕮 4 总结

操作系统,如默默守护的守夜者,无声地管理硬件与软件的交流,为计算机创造和谐秩序。

它是无形的引导者,让复杂的任务变得井然有序,为用户提供无忧体验。

操作系统的巧妙设计,让计算机变得更加智能高效,让人与科技之间的交流更加顺畅。

在每一次启动中,它如信任的伙伴,带领我们进入数字世界的奇妙旅程。

渴望挑战操作系统的学习路径和掌握进阶技术?不妨点击下方链接,一同探讨更多操作系统的奇迹吧。我们推出了引领趋势的💻OS专栏:《OS从基础到进阶》 ,旨在深度探索OS的实际应用和创新。🌐🔍

相关文章
|
3天前
|
算法 UED
深入理解操作系统:虚拟内存管理机制
【7月更文挑战第4天】在数字时代的浪潮中,操作系统的虚拟内存管理机制如同一座精巧的时间桥梁,连接着有限的物理资源与无限的程序需求。本文将揭开这座桥梁的秘密,从虚拟内存的基本概念出发,逐步深入到页面置换算法的世界,探讨它们如何影响系统性能和用户体验。通过对比分析不同的页面置换策略,我们旨在为读者提供一种全新的视角,以理解和评估现代操作系统中这一至关重要的功能。
6 1
|
5天前
|
存储 缓存 算法
操作系统的内存管理机制及其对系统性能的影响
本文深入探讨了操作系统中内存管理的关键技术和策略,以及它们如何影响计算机系统的整体性能。通过分析不同的内存分配算法、虚拟内存技术、以及缓存策略,本文旨在揭示这些机制对于提高资源利用效率、减少延迟和优化用户体验的重要性。结合最新的研究成果和实际案例,本文为读者提供了对操作系统内存管理深度理解的视角,并讨论了未来可能的发展趋势。
|
6天前
|
存储 安全 Linux
深入理解操作系统:从进程管理到内存分配
【6月更文挑战第30天】在数字时代的心脏,操作系统是现代计算不可或缺的组成部分。本文将深入探讨操作系统的核心功能,包括进程管理、内存分配以及文件系统管理。我们将通过实际案例分析,揭示这些机制如何在提高计算机性能的同时保证资源的有效利用。文章旨在为读者提供对操作系统工作原理的深刻理解,并展示其在现代技术中的应用价值。
|
11天前
|
存储 缓存
操作系统的虚拟内存管理机制
在现代计算机系统中,虚拟内存是一种至关重要的内存管理技术。它允许操作系统使用硬盘空间来扩展物理内存容量,从而支持更多并发运行的程序。本文将深入探讨虚拟内存的概念、实现方式以及其在操作系统中的作用和重要性。
|
11天前
|
存储 算法
探索现代操作系统中的虚拟内存管理技术
在数字时代的浪潮中,操作系统的心脏——虚拟内存管理技术,正以它独有的韵律跳动。本文将带你穿梭于操作系统的迷宫,揭开虚拟内存如何巧妙地扩展有限的物理内存之谜。从分页机制的精妙设计到交换空间的策略运用,我们将一探究竟。你将看到,虚拟内存不仅仅是一个存储数据的地方,它是速度与效率的协调者,是多任务处理的幕后英雄。随着技术的演进,虚拟内存管理不断优化,为应用程序提供了一片更为广阔的运行天地。让我们一同走进这个充满智慧的世界,感受操作系统中虚拟内存管理的魅力所在。
13 1
|
3天前
|
存储 算法 数据安全/隐私保护
探索现代操作系统的内存管理技术
【7月更文挑战第4天】本文将深入探讨现代操作系统中内存管理的关键技术和策略,包括虚拟内存、分页与分段、以及内存分配算法。我们将了解这些技术如何优化资源使用,提高系统性能,并确保数据安全和完整性。
|
4天前
|
缓存 算法 UED
操作系统中的内存管理技术及其性能影响
在现代计算机系统中,操作系统的内存管理机制对系统性能有着至关重要的影响。本文将深入探讨内存管理的关键技术,包括虚拟内存、分页和分段,以及它们如何影响系统的响应速度和资源利用效率。通过分析不同内存管理策略的性能表现,并结合最新的研究成果,本文旨在为读者提供关于优化内存管理以提高系统性能的实用指导。
|
5天前
|
算法 安全 UED
深入理解操作系统的虚拟内存管理机制
【7月更文挑战第2天】在现代计算机系统设计中,虚拟内存是实现内存管理高效、安全和可扩展的关键技术。本文将深入探讨虚拟内存的管理机制,包括分页技术、内存分配策略以及页面替换算法等核心概念。通过分析虚拟内存如何优化物理内存的使用,提高系统的运行效率,并讨论其在实际操作系统中的应用和面临的挑战,旨在为读者提供对虚拟内存管理机制的全面理解。
|
6天前
|
存储 算法 程序员
深入理解操作系统:从进程管理到内存分配
【7月更文挑战第1天】在数字时代的心脏,操作系统(OS)扮演着枢纽的角色。本文将探索操作系统的核心概念,包括进程管理、内存分配和文件系统,同时揭示这些机制如何协同工作以确保计算机系统的高效运行。我们将从用户和程序员的视角出发,分析操作系统如何在幕后默默支撑着我们的数字生活。
|
7天前
|
存储 算法 调度
深入理解操作系统:虚拟内存管理的艺术
【6月更文挑战第29天】在数字世界的无限风光背后,隐藏着一个不为人知的复杂世界——操作系统。本文将揭开操作系统中最为精妙的设计之一——虚拟内存管理的神秘面纱,从基础概念出发,逐步探索其背后的原理与实现机制。我们将通过生动的比喻和实例,带领读者领略虚拟内存如何在有限的物理资源上创造出无限的可能,以及它如何优化系统性能,提升用户体验。准备好了吗?让我们一同潜入操作系统的心脏,一探究竟。