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

本文详细介绍了虚拟内存的基础概念,包括传统存储管理的缺点、局部性原理以及其实现方法。重点讲解了请求分页管理中的页表机制、缺页中断和地址变换,以及各种页面置换算法如OPT、FIFO、LRU和时钟置换。深入探讨了操作系统如何管理硬件与软件资源,提供了一个从基础到进阶的学习路径。
摘要由CSDN通过智能技术生成

在这里插入图片描述

在这里插入图片描述

🌈个人主页:godspeed_lucip
🔥 系列专栏:OS从基础到进阶



🐹1 虚拟内存的基本概念

🦓1.1 总览

image1

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

image2

🦓1.3 局部性原理

image3

🦓1.4 虚拟内存

🦝1.4.1 定义

image4
image5

🦝1.4.2 特征

image6

🦓1.5 如何实现虚拟内存

🦝1.5.1 需要解决的两个问题

(1)
image7
此时操作系统需要提供请求调页(请求调段)功能
(2)
image8
此时操作系统需要提供页面置换(段置换功能)

🦝1.5.2 常采用的技术

image9

🦓1.6 总结

image10

🐹2 请求分页管理方法

🦌2.1 总览

image1

🦌2.2 页表机制

🦝2.2.1 需考虑的问题

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

🦝2.2.2 页表的基本结构

image3
访问字段:优先将访问次数较少的内存块调出内存
修改位:在将内存块调出内存时,对于已经修改过的内存块,需要将修改内容重新写入外存。
其他字段较为简单不再赘述

🦌2.3 缺页中断机制

🦝2.3.1 什么是缺页中断机制

image4

🦝2.3.2 过程

image5
image6

🦌2.4 地址变换机制

🦝2.4.1 过程

与普通页表的地址变化过程类似。注意此处是引入了快表的
image7
当发生缺页中断时,需要进行的护处理如下:
image8

🦝2.4.2 补充细节

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

🦌2.5 总结

image10

🐹3 页面置换算法

🐯3.1 总览

image1

🐯3.2 最佳置换算法(OPT)

🐶3.2.1 算法思想

image2

🐶3.2.2 例子

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

🐶3.2.3 缺点

(1)是一种理想算法
image5
(2)注意
image6

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

🐶3.3.1 算法思想

image7

🐶3.3.2 例子

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

🐶3.3.3 缺点

image10

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

🐶3.4.1 算法思想

image11

🐶3.4.2 例子

image12
假如系统的内存块数量为4,且会访问的页面串为:
1,8,1,7,8,2,3
首先,页面会逐渐将内存块填满,如图:
image13
接着,系统访问7号页面,发现内存中没有,于是发生缺页异常,此时我们可以发现现有的页面1872中,它们的自上次被访问以来所经历的时间依次为3、2、1、0。所以系统将1号页面换出,换为3号页面。
我们在做题时,也可以逆序查找。比如此处内存中的页面为1872,而它们的逆序页面号为2、8、7、1,所以1是最久没有使用的,可以将其替换。

🐶3.4.3 缺点

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

🐯3.5 时钟置换算法

🐶3.5.1 算法思想

image15
访问位示意图:
image16

🐶3.5.2 例子

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

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

🐶3.6.1 算法思想

image18

🐶3.6.2 算法实现方法

image19

🐶3.6.3 例子

image20
(1)只需一轮扫描:
image21

(2)需要两轮扫描:
image22

(3)需要三轮扫描
image23

(4)需要四轮扫描
image24

🐶3.6.4 对算法的进一步理解

image25

🐯3.7 总结

image26

🕮 4 总结

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

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

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

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

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

在这里插入图片描述

在这里插入图片描述

评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值