首页 > 编程语言 >操作系统-页面置换算法

操作系统-页面置换算法

时间:2024-09-26 10:23:49浏览次数:16  
标签:操作系统 置换 算法 内存 进来 序列 缺页 替换 页面

简介

期末考试中常考的页面置换算法可能有三种,分别是先进先出(FIFO),最佳置换(OPT)和最久未使用(LRU)

本篇文章会用一道例题来讲解这三种算法的思路和解题过程;

题目

假设有这样一个操作系统,其内存中有3个空闲页面框(题目也有可能是描述成M3,M是Memory的简写)。进程依次请求页面号为以下序列:7, 0, 1, 2, 0, 3, 0, 4, 2, 3, 0, 3, 2。在开始时,所有页面框都是空的。对于每种页面置换算法(FIFO、LRU、OPT),计算并记录发生的页故障次数,和缺页率,用表格展示在解答过程中;

分析

内存有三个空闲框,说明一次性可以最多接受三个序列;

是否缺页指的是:在内存块中是否被替换掉的+原本内存块中存在的;

FIFO:先进先出,只需要找到离下一次序列号进来的时候上一次最多的替换掉;

LRU:最久未使用

OPT:最佳置换,只需要在序列栏对比内存中已经存在的,往后看离的最远的替换掉内存块中的序列

答案

FIFO(先进先出算法解答)

描述7012030423032
M1777
M200
M31
是否缺页

上述表格,因为前三次序列,并不存在置换,所以直接填进表格里面,从第四次开始分析;

第四次:进来2,那么7作为先进来的序列就需要替换掉,所以就变成2,0,1,缺页标记为是

第五次:进来0, 0在序列中已经存在,所以这一页不变,还是2,0,1,缺页标记为否

第六次: 进来3,3在序列中不存在,所以替换掉0,结果变成2,3,1,缺页标记为是

第七次:进来0,0在序列中不存在,所以替换掉1,结果变成2,3,0,缺页标记为是;

...后续的结果像上面这样推导就行了;所以最后的答案在下表中描述为:

描述7012030423032
M17772224440
M2000333222
M311100033
是否缺页

所以缺页次数一共是:10次,总次数为13,缺页率为10/13≈78%

OPT(最佳置换算法)

描述7012030423032
M1777
M200
M31
是否缺页

根据描述,最佳置换算法需要在序列中对比内存块找到最近不会使用的;

第四次:进来2,此时内存块中是7,0,1;7和1在未来都不会使用(因为你看后续的所有序列号),所以随便换一个,就变成了2,0,1

第五次:进来0,0在内存中已经存在,所以不发生置换,此时还是2,0,1

第六次:进来3,后续中会用到2和0,所以去掉1,变成了2,0,3

第七次:进来0,0在内存中存在,所以还是2,0,3

第八次:进来4,后续序列中,先进来2和3,所以把0替换掉,变成2,3,4

第九次:进来2,不发生替换,还是2,3,4

第十次:进来3,不发生替换,结果2,3,4

第十一次:进来0,在未来3和2会用到,踢掉4,结果是3,2,0

第十二次:不发生置换

第十三次:不发生置换

所以上述分析在下方表格为:

描述7012030423032
M17772222
M2000040
M311333
是否缺页

所以总的缺页次数为:7次,总次数为13次。缺页率为:7/13≈54%

LRU(最久未使用算法)

该算法和OPT类似,只不过OPT是往序列后面看,LRU是往序列前面看最久未使用的;

描述7012030423032
M1777
M200
M31
是否缺页

第四次:进来2,此时内存中是序列号7,0,1,从2往前数发现7是最久未使用的,所以替换掉7,变成2,0,1

第五次:进来0,此时不发生置换,还是2,0,1

第六次:进来3,替换掉1,变成2,0,3

后续跟着规律往下填就行,结果如下:

描述7012030423032
M1777224440
M200000033
M31133222
是否缺页

所以此时缺页次数为:9次,总次数为13,缺页率为:9/13≈69%

标签:操作系统,置换,算法,内存,进来,序列,缺页,替换,页面
From: https://blog.csdn.net/2401_87105969/article/details/142413644

相关文章

  • 【算法】C++KMP算法的简洁实现
    目录简介next数组匹配完整代码简介对于朴素的字符串匹配算法,如果想在主串中寻找到第一次出现子串的位置,需要依次枚举主串中的每一个位置作为起始位置进行匹配尝试,如果主串中存在许多与子串相似结构的部分,那么朴素算法会进行大量的无用枚举,时间复杂度非常之高。KMP算法......
  • 【鸟类识别系统】+计算机毕设项目+卷积神经网络算法+人工智能+深度学习+模型训练+Pyth
    一、介绍鸟类识别系统。本系统采用Python作为主要开发语言,通过使用加利福利亚大学开源的200种鸟类图像作为数据集。使用TensorFlow搭建ResNet50卷积神经网络算法模型,然后进行模型的迭代训练,得到一个识别精度较高的模型,然后在保存为本地的H5格式文件。在使用Django开发Web网页端操作......
  • 求最大公约数的三种算法
    #include<iostream>#include<vector>#include<algorithm>usingnamespacestd;intgcdByBruteForce(inta,intb){for(inti=min(a,b);i>0;--i){if(a%i==0&&b%i==0){returni;......
  • 矿山井下/传送带堆料检测AI算法的检测作用、工作原理及其解决方案
    传送带堆料分为两种情况,一种是传送带的井下堆料检测AI算法,一种是传送带上面的堆料检测AI算法,传送带井下堆料检测AI算法是在带式输送机的漏煤下方井下安装摄像仪,通过视频分析检测井下堆煤情况,当洒煤堆积到一定程度后,智慧矿山版ai盒子自动产生报警,并语音通知值班人员,也可通过前端音箱......