常见的页面置换算法概述 OPT、FIFO、SCR、CLOCK、改进型CLOCK、MIN、WS

个人博客原文链接

最佳页面置换算法 OPT算法

最佳页面置换算法是Belady于1966年提出的一种理论上的算法。是一种保证最少的缺页率的理想化算法。

算法描述

输入页面号引用串:

  • 如果页框中的某个页面P以后永不使用,则该页面为淘汰页面Pt。
  • 如果每个P都会再次被访问,那么其中最长未来时间内不再被访问的页面为淘汰页面Pt。

先进先出页面置换算法 FIFO算法

算法描述

优先淘汰最早进入内存的页面,亦即在内存中驻留时间最久的页面。


第二次机会算法 SCR算法

第二次机会算法的基本思想是与FIFO相同的,但是有所改进,避免把经常使用的页面置换出去

算法描述
  • 设置一个访问位
  • 当淘汰一个页面时,要检查其访问位:若访问位是1,给它第二次机会,选择下一个FIFO页面,并将其访问位置为0;若访问位是0,则淘汰它
  • 另外,访问到访问位为0的页面,将其访问位重新置为1

Clock页面置换算法

算法描述
  • 当某一页首次装入内存中时,则将该页框的使用位设置为1;当该页随后被访问到时(在访问产生缺页中断之后),它的使用位也会被设置为1
  • 置换条件是当前使用位为0;当一页被置换时,该指针被设置成指向缓冲区中的下一页框(不修改下一页框的使用位)
  • 当需要置换一页时,操作系统扫描缓冲区,以查找使用位被置为0的一页框。每当遇到一个使用位为1的页框时,操作系统就将该位重新置为0
  • 如果在这个过程开始时,缓冲区中所有页框的使用位均为0时,则选择遇到的第一个页框置换
  • 如果所有页框的使用位均为1时,则指针在缓冲区中完整地循环一周,把所有使用位都置为0,并且停留在最初的位置上,置换该页框中的页
其他博主见解

每一次进行替换指针的位置就从替换数移到下一个位置;每一次进行访问时,则指针保持不动 ( 原文链接

概括说就是,替换指针后移一位(循环),不替换指针不动。

流程图

在这里插入图片描述

注(个人理解,不喜勿喷,欢迎指教hhh)

Clock算法看上去和SCR算法很像,但它们还是有区别的,其中一点区别在于:clock算法做得是循环扫描,淘汰的是下一个遇到的使用位为0的页;而SCR算法是FIFO算法的改进版,淘汰的是最先进入的访问位为0的页。


改进型的Clock算法

改进型的Clock算法需要综合考虑某一内存页面的访问位和修改位来判断是否置换该页面
设访问位为A、修改位为M

M为0M为1
A为0该页面既为被访问,又未被修改,是最佳淘汰页该页面最近s未被访问,但已被修改,并不是很好的淘汰页
A为1该页面最近已被访问,但未被修改,该页有可能在被访问该页最近已被访问并且被修改,该页可能再被访问

1类(A=0,M=0):表示该页最近既未被访问、又未被修改,是最佳淘汰页。

2类(A=0,M=1):表示该页最近未被访问,但已被修改,并不是很好的淘汰页。

3类(A=1,M=0):最近已被访问,但未被修改,该页有可能再被访问。

4类(A=1,M=1):最近已被访问且被修改,该页有可能再被访问。

算法描述
  • 从指针所指示的当前位置开始,扫描循环队列,寻找A=0且M=0的第一类页面,将所遇到的第一个页面作为所选中的淘汰页。在第一次扫描期间不改变访问位A。
  • 如果第一步失败,即查找一周后未遇到第一类页面,则开始第二轮扫描,寻找A=0且M=1的第二类页面,将所遇到的第一个这类页面作为淘汰页。在第二轮扫描期间,将所有经过的页面的访问位置0。
  • 如果第二步也失败,即未找到第二类页面,则将指针返回到开始的位置,并将所有的访问位复0。(此时已无3类、4类页框)然后,重复第一步,如果仍失败,必要时再重复第二步,此时就一定能够找到被淘汰的页。
流程图

在这里插入图片描述

最近最少使用算法 LRU算法

算法概述

思路是,发生缺页中断时,选择未使用时间最长的页面置换出去


局部最佳页面替换算法 MIN算法

算法描述
  • 滑动窗口(τ):间隔(t,t + τ)即从当前页,到第τ个页,被称为滑动窗口(实际长度为τ+1)
  • 无论发生缺页与否,算法在每一步都要考虑引用串
  • 如果(驻留集中的)此页面在时间间隔(t,t + τ)(t为当前时刻)内未被再次引用,那么就将该页面移出;否则保留该页面到再次被引用

工作集置换算法 WS算法

P.J.Denning提出工作集(Working Set replacement, WS)模型,用来对局部最佳页面替换算法进行模拟实现,也使用滑动窗口概念,但并不向前查看页面引用串,而是基于程序局部性原理向后看,在任何给定时刻,一个进程不久的将来所需内存页框数可通过考察其最近时间内的内存需求做出估计

算法描述
  • 进程工作集:在某一段时间间隔内进程运行所需访问的页面集合
  • 简单说就是与MIN算法相反,滑动窗口为(t - τ,t);如果(工作集中的)此页面在时间间隔(t - τ,t)(t为当前时刻)未被使用过,那么就将该页面移出;否则保留该页面到再次被引用或下次移出
  • 4
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值