全球旧事资料 分类
实验二页面置换算法实现
一、实验目的
(1)了解内存分页管理策略(2)掌握调页策略(3)掌握一般常用的调度算法(4)学会各种存储分配算法的实现方法。(5)了解页面大小和内存实际容量对命中率的影响。
二、实验内容
采用页式分配存储方案,通过分别计算不同算法的命中率来比较算法的优劣,同时也考虑页面大小及内存实际容量对命中率的影响,设计一个虚拟存储区和内存工作区,并使用下述算法来模拟实现页面的置换:
1先进先出的算法(FIFO)2最近最久未使用算法(LRU)3最佳置换算法(OPT)实验分析在进程运行过程中,若其所访问的页面不存在内存而需要把它们调入内存,但内存已无空闲时,为了保证该进程能够正常运行,系统必须从内存中调出一页程序或数据送磁盘的对换区中。但应调出哪个页面,需根据一定的算法来确定,算法的好坏,直接影响到系统的性能。一个好的页面置换算法,应该有较低的页面更换频率。21先进先出(FIFO)页面置换算法当需要访问一个新的页面时,首先查看物理块中是否就有这个页面,若要查看的页面物理块中就有,则直接显示,不需要替换页面;如果要查看的页面物理块中没有,就需要寻找空闲物理块放入,若存在有空闲物理块,则将页面放入;若没有空闲物理块,则替换页面。并将物理块中所有页面timer。22最近久未使用LRU置换算法的思路最近久未使用置换算法的替换规则,是根据页面调入内存后的使用情况来进行决策的。该算法赋予每个页面一个访问字段,用来记录一个页面自上次被访问以来所经历的时间,当需淘汰一个页面的时候选择现有页面中其时间值最大的进行淘汰。23最佳(OPT)置换算法的思路其所选择的被淘汰的页面,是以后不使用的,或者是在未来时间内不再被访问的页面,采用最佳算法,通常可保证获得最低的缺页率。
三、实验流程
31系统功能图
f图31系统功能图32算法流程图1)先进先出(FIFO)页面置换算法流程图
图32先进先出页面置换算法流程图2)最近久未使用LRU置换算法
f图33最近久未使用置换算法流程图3)最佳(OPT)置换算法
图34最佳置换算法流程图
f四、源程序
i
cludeiostreamhi
cludestdlibhi
cludetimehi
cludestdiohdefi
eL20页面长度最大为20i
tM内存块structPro定义一个结构体
i
t
umtimeI
puti
tmPropL打印页面走向状态
cout
好听全球资料 返回顶部