十、页面置换算法

简介: 十、页面置换算法

1、功能与目标


功能: 当缺页中断发生,需要调入新的页面而内存已满时,选择内存当中哪个物理页面被置换。


目标: 尽可能地减少页面的换金换出次数(即缺页中断的次数)。具体来说,把未来不再使用的或者短期内较少使用的页面换出,通常只能在局部性原理指导下依据过去的统计数据来进行预测。


页面锁定(frame lock): 用于描述必须常驻内存的操作系统的关键部分或者时间关键(time-critical)的应用程序。实现的方法是:在页表中添加锁定标志位(lock bit)。




2、最优页面置换算法



基本思路: 当一个缺页中断发生时,对于保存在内存当中的每一个逻辑页面,计算在他的下一次访问之前,还需要等待多长的时间,从中选出时间最长的那个,作为被置换的页面。但这只是一种理想的情况,在实际系统中时无法实现的,因为操作系统无法知道每一个页面要等待多长时间之后才会再次被访问。Anyway,最优页面置换算法依然可以用作其他算法的性能评价依据(在一个模拟器上运行某个程序,并记录每一次页面访问的情况,在第二遍运行时即可用最优页面置换算法)。


最优页面置换算法的示意图如下图所示。


764a37557f754cb9881c7ba294324e25.png





3、先进先出算法-FIFO



基本思路: 选择在内存中驻留时间最长的页面并将之淘汰。具体来说,系统会维护一个链表,记录了所有位于内存之中的逻辑页面。从链表的排列顺序来看,链首页面的驻留时间最长,链尾页面的驻留时间最短。当发生一个缺页中断时,把链首的页面淘汰出局,并把新的页面添加到链表的末尾。


性能较差: 调出的页面可能有经常要访问的页面,并且有"Belady"现象。所以FIFO算法很少单独使用。


609dec722b2a4e0e89c7f082a8406650.png


FIFO算法的示意图如上图所示,其中Fault行中的红点表示在某一次执行过程中产生了缺页中断。




4、最近最久未使用算法-Least Recently Used


基本思路: 当一个缺页中断发生时,选择最久未使用的那个页面,并淘汰之。LRU是对最优页面置换算法的一个近似,其依据是程序的局部性原理,即在最近一小段时间(最近几条指令)内,如果某些页面被频繁地访问,那么在将来一小段时间内,他们还可能会再一次被频繁地访问。反过来说,如果在过去某些页面长时间未被访问,那么在将来他们还可能会长时间地得不到访问。


9be0fad379664600a09cea8e60510332.png


在这里插入图片描述

LRU算法的示意图如上图所示,其中Fault行中的红点表示在某一次执行过程中产生了缺页中断。


实现LRU可以使用的数据结构思路:


首先可以考虑使用链表,最近各个使用的页面作为首节点,最久未被使用的作为尾结点。每一次访问内存时,找到相应的页面,把他从链表中摘下来,在移动到链表首。每次缺页中断时,淘汰链表尾部的页面。


·还可以使用队列,利用其先进先出的特点,当访问某页时,将此页号压入队列,之后考察队列中是否有榆次页面相同的页号,若有则将其删除(相当于重新构建了一次队列,步入链表划算)。当需要淘汰一个页面时,直接将最先压入队列的页面淘汰即可(先进先出)。




5、时钟页面置换算法



Clcok页面置换算法,LRU的近似,对FIFO的一种改进,其基本思路为: 需要用到页表项当中的访问位Access bit,当一个页面被装入内存时,把该位初始化为0,然后如果这个页面被访问(读/写),则把该位置置为1;把各个页面组织成环形链表(类似时钟表面),把指针指向最老的页面(最先进来的);当发生一个缺页中断时,考察指针所指向的最老的页面,若它的访问位为0,立即淘汰;若访问位为1,则把该位置置为0,然后指针往下移动一格。如此下去,直到找到被淘汰的页面,然后把指针移动到它的下一格。


fc72656e7e564521a14053cddfdb3fa1.png


Clock置换算法流程如上图所示。

44fd206a1792497cb55ef0ffa4fe2651.png

Clock置换算法的示意图如上图所示。




6、二次机会法-Enhanced Clock Algorithm


对于进行了“读”操作和“写”操作的页分别进行处理,优先替换掉没有进行“写”操作的页(称之为“脏”页),因为这种页替换掉之后需要重新写回到内存之中进行信息的更新操作,而只进行了“读”操作的页无需重新写回到内存之中。


因为替换“脏”页的代价巨大,所以对上述的Clock算法进行修改,使他允许脏页总是在一次时钟头扫描中保留下来,将脏位为1的页的脏位置为0,同时使用脏位和使用位来指导替换,最终选择脏位和使用位均为0的页进行替换。



7cd4af20004544d9ab0d88c7de2dc01e.png


Enhanced Clock置换算法的示意图如上图所示。




7、最不常用算法-Least Frequently Used



基本思路: 当一个缺页中断发生时,选择访问次数最少的那个页面,并淘汰。


实现方法: 对每个页面设置一个访问计数器,每当一个页面访问时,该页面的访问计数器加1。在发生缺页中断时,淘汰计数值最小的那个页面。











相关文章
|
8月前
|
存储 算法
【操作系统】虚拟存储管理-页面置换算法
【操作系统】虚拟存储管理-页面置换算法
799 0
|
2月前
|
机器学习/深度学习 算法 数据挖掘
提高时钟置换算法的性能
【10月更文挑战第25天】通过上述一种或多种方法的综合应用,可以在不同程度上提高时钟置换算法的性能,使其更好地适应各种复杂的系统环境和应用场景,提高虚拟内存管理的效率和系统的整体性能。
128 62
|
2月前
|
算法
时钟置换算法
【10月更文挑战第25天】时钟置换算法是一种简单而有效的页面置换算法,它通过使用位标志和环形链表的结构,在一定程度上平衡了算法的复杂性和性能表现。虽然它存在一些局限性,但通过改进和与其他算法的结合,可以在不同的系统环境中发挥重要作用,提高虚拟内存管理的效率和系统的整体性能。
172 51
|
2月前
|
算法
虚拟内存的页面置换算法有哪些?
【10月更文挑战第25天】不同的页面置换算法各有优缺点,在实际应用中,操作系统会根据不同的应用场景和系统需求选择合适的页面置换算法,或者对算法进行适当的改进和优化,以平衡系统的性能、开销和资源利用率等因素。
69 5
|
3月前
|
算法
有哪些页面置换算法?
页面置换算法(Page Replacement Algorithms)在计算机操作系统中用于管理虚拟内存。
59 0
|
5月前
|
算法 程序员
理解操作系统内存管理:页面置换算法全解析
大家好,我是小米,热爱分享技术的大哥哥!今天聊的是操作系统中的页面置换算法。它解决的是内存满载时,如何选择合适的页面移出以腾出空间的问题。主要有三种算法:FIFO(先进先出),简单但性能不佳;LRU(最近最久未使用),考虑时间局部性,性能较好但实现较复杂;OPT(最佳置换),理论上最优但无法实际应用。这些算法各有千秋,在实际应用中需根据场景选择最合适的方案。希望这能帮大家更好地理解内存管理的核心机制!
244 2
|
8月前
|
算法
页面置换算法
页面置换算法
62 1
|
8月前
|
算法
操作系统OPT算法(最佳页面替换算法)
操作系统OPT算法(最佳页面替换算法)
203 0
|
12天前
|
机器学习/深度学习 算法
基于改进遗传优化的BP神经网络金融序列预测算法matlab仿真
本项目基于改进遗传优化的BP神经网络进行金融序列预测,使用MATLAB2022A实现。通过对比BP神经网络、遗传优化BP神经网络及改进遗传优化BP神经网络,展示了三者的误差和预测曲线差异。核心程序结合遗传算法(GA)与BP神经网络,利用GA优化BP网络的初始权重和阈值,提高预测精度。GA通过选择、交叉、变异操作迭代优化,防止局部收敛,增强模型对金融市场复杂性和不确定性的适应能力。
145 80
|
5天前
|
机器学习/深度学习 算法
基于遗传优化的双BP神经网络金融序列预测算法matlab仿真
本项目基于遗传优化的双BP神经网络实现金融序列预测,使用MATLAB2022A进行仿真。算法通过两个初始学习率不同的BP神经网络(e1, e2)协同工作,结合遗传算法优化,提高预测精度。实验展示了三个算法的误差对比结果,验证了该方法的有效性。

热门文章

最新文章