- 1、本文档共18页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
模拟页式存储管理
PAGE
PAGE 1
操作系统课程设计报告
项目:模拟请求页式存储管理
班级:12计师
姓名:马泽娜
学号:2012035144038
指导老师:黄超老师
日期:2014-06-27
一、目的和要求
实训目的
(1)通过编写和调试存储管理的模拟程序以加深对存储管理方案的理解。熟悉虚存管理的各种页面淘汰算法
(2)通过编写和调试地址转换过程的模拟程序以加强对地址转换过程的了解。
2、实训要求
编写并调试完成请求页式存储管理程序。
页面置换算法:最佳置换算法(OPT)、先进先出算法(FIFO)和最近最少用算法(LRU)。
要求打印每个页面置换算法的页面置换变化示意图、缺页中断次数和缺页中断率,以比较各种算法的优缺点。
二、设计思路及过程
1、概要设计
1.1 问题概述
根据三种不同的置换算法(FIFO、LRU、OPT),依据其不同的算法方式,分别计算该页面引用串在不同算法下的缺页次数与缺页率,并显示各页面的变化情况。
1.2 内容分析
对于该课程设计中模拟的请求页式存储管理的页面置换过程,只要掌握其中最基本的三种算法,包括FIFO、LRU及OPT。另外,对于同一个页面引用串,要求能够调用不同的算法对它进行操作。
2、过程设计
2.1模块设计
在下图的主模块设计图中,只注重描绘了请求页式存储管理的三种主要算法,未描绘出细节部分。
请求
请求页式存储管理
先进先出算法
最近最久未用算法
最佳置换算法
图2.1 请求页式存储管理的主模块设计图
2.2 算法原理分析
要成功实现算法,首先要知道各个方法是怎么做的,即原理是怎样的,下面是三种算法的原理。
(1)FIFO算法:该算法认为刚被调入的页面在最近的将来被访问的可能性很大,而在主存中滞留时间最长的页面在最近的将来被访问的可能性很小。因此。FIFO算法总是淘汰最先进入主存的页面,即淘汰在主存中滞留时间最长的页面。
(2)LRU算法是最近最久未使用,当当前内存中没有正要访问的页面时,置换出在当前页面中最近最久没有使用的页面。该算法总是选择最近一段时间内最长时间没有被访问过的页面调出。它认为那些刚被访问过的页面可能在最近的将来还会经常访问他们,而那些在较长时间里未被访问的页面,一般在最近的将来再被访问的可能性较小。
(3)OPT算法是未来最远出现,当当前内存中没有正要访问的页面时,置换出当前页面中在未来的访问页中最远出现的页面或再也不出现的页面。用该算法选择的被淘汰的页面将是以后永远不再使用,或者是在将来最长时间内不再被访问的页面,这样产生的缺页中断次数将会是最少的。采用OPT算法通常可获得最低的缺页中断率,然而却需要预测出程序的页面引用串,这是无法预知的,不可能对程序的运行过程做出精确的断言,所以说这是一种理想化的算法,无法实现。但是这个算法可以作为衡量其他算法的标准。
2.3 程序流程图
本次课程设计的主要流程是3种置换算法的流程图,流程图如下所示:
先进先出算法(FIFO)
开始
开始
产生指令地址流初始化页表
产生指令地址流初始化页表
访问一个指令地址,计算该地址所在页的页号
访问一个指令地址,计算该地址所在页的页号
在该页在主存?
在
该页在主存?
不在
不在
页表中是否有空白物理块?有
页表中是否有空白物理块?
有
没有
没有
FIFO:置换出最先进来的页面
FIFO:置换出最先进来的页面
调入当前所需的页
调入当前所需的页
打印指令地址、它所在的页号及页表信息
打印指令地址、它所在的页号及页表信息
否所有指令地址是否已访问完?
否
所有指令地址是否已访问完?
是
是
结束
结束
FIFO算法流程图
最近最少用算法(LRU)
开始
开始
产生指令地址流初始化页表
产生指令地址流初始化页表
访问一个指令地址,计算该地址所在页的页号
访问一个指令地址,计算该地址所在页的页号
在该页在主存?
在
该页在主存?
不在
不在
有页表中是否有空白物理块?
有
页表中是否有空白物理块?
没有
没有
LRU:置换出当前页面中最近最久没有使用的页面
LRU:置换出当前页面中最近最久没有使用的页面
调入当前所需的页
调入当前所需的页
打印指令地址、它所在的页号及页表信息
打印指令地址、它所在的页号及页表信息
否所有指令地址是否已访问完?
否
所有指令地址是否已访问完?
是
是
结束
结束
LRU算法流程图
最佳置换算法(OPT)
开始
开始
产生指令地址流初始化页表
产生指令地址流初始化页表
访问一个指令地址,计算该地址所在页的页号
访问一个指令地址,计算该地址所在页的页号
在该页在主存?
在
该页在主存?
不在
不在
有页表中是否有空白物理块?
有
页表中是否有空白物理块?
没有
没有
OPT:替换内存中将来不出现或离当前最远的页面
OPT
文档评论(0)