- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
综合性实验报告
专业 年级 班级:
课程名称
操作系统
指导教师
学号姓名
实验地点
实验时间
项目名称
页面置换算法
实验类型
综合性
一、实验目的
1.学习常见的4种页面置换算法:最佳置换算法(OPT),先进先出页面置换算法(FIFO),最近最久未使用页面算法(LRU),最少使用置换算法(LFU)。
2. 编写函数并计算输出上述各种算法的命中率。二、总体设计(设计原理、设计方案及流程等)
设计原理:OPT页面置换算法
OPT所选择被淘汰的页面是已调入内存,且在以后永不使用的,或是在最长时间内不再被访问的页面。因此如何找出这样的页面是该算法的关键。可为每个页面设置一个步长变量,其初值为一足够大的数,对于不在内存的页面,将其值重置为零,对于位于内存的页面,其值重置为当前访问页面与之后首次出现该页面时两者之间的距离,因此该值越大表示该页是在最长时间内不再被访问的页面,可以选择其作为换出页面。
FIFO页面置换算法
FIFO总是选择最先进入内存的页面予以淘汰,因此可设置一个先进先出的忙页帧队列,新调入内存的页面挂在该队列的尾部,而当无空闲页帧时,可从该队列首部取下一个页帧作为空闲页帧,进而调入所需页面。
LRU页面置换算法
LRU是根据页面调入内存后的使用情况进行决策的,它利用“最近的过去”作为“最近的将来”的近似,选择最近最久未使用的页面予以淘汰。该算法主要借助于页面结构中的访问时间time来实现,time记录了一个页面上次的访问时间,因此,当须淘汰一个页面时,选择处于内存的页面中其time值最小的页面,即最近最久未使用的页面予以淘汰。
LFU页面置换算法
LFU要求为每个页面配置一个计数器(即页面结构中的counter),一旦某页被访问,则将其计数器的值加1,在需要选择一页置换时,则将选择其计数器值最小的页面,即内存中访问次数最少的页面进行淘汰。
设计流程:
河南师范大学软件学院.
1.通过随机数产生一个指令序列,共320条指令。
2.指令序列变换成页地址流
3.计算并输出下述各种算法在不同内存容量下的命中率。
4.在主函数中生成要求的指令序列,并将其转换成页地址流;在不同的内存容量下调用上述函数使其计算并输出相应的命中率。
三、实验步骤(包括主要步骤、代码分析等)
主要代码:
1.页面结构
typedef struct{
int pn, pfn, counter, time;
} pl_type ;
pl_type pl[total_vp];
其中pn为页面号(页号),pfn为页帧号(物理块号),counter为一个周期内访问该页面的次数,time为访问时间;pl[total_vp]为页面结构数组,由于共有320条指令,每页可装入10条指令,因此虚页长total_vp的值为32。
将此结构封装到Pahg.h文件中。
2.页帧控制结构
struct pfc_struct{
int pn, pfn;
struct pfc_struct *next;};
typedef struct pfc_struct pfc_type;
pfc_type pfc[total_vp], *freepf_head, *busypf_head, *busypf_tail;
其中pfc[total_vp]定义用户进程的页帧控制结构数组,在该实验中,用户内存工作区是动态变化的,最多可达到用户进程的虚页数目,即32个物理块。
*freepf_head为空闲页帧头的指针
*busypf_head为忙页帧头的指针
*busypf_tail忙页帧尾的指针
讲此结构封装到PageControl.h头文件中。
3.主要函数
(1) void initialize(int): 初始化函数
河南师范大学软件学院.
该函数主要对页面结构数组pl和页帧结构数组pfc进行初始化,如置页面结构中的页面号pn,初始化页帧号pfn为空,访问次数counter为0,访问时间time为-1;同样对页帧数组进行初始化,形成一个空闲页帧队列。
(2) void OPT(int): 计算使用最佳页面算法时的命中率
(3) void FIFO(int): 计算使用先进先出页面置换算法时的命中率
(4) void LRU(int): 计算使用最近最久未使用页面置换算法时的命中率
(5) void LFU(int): 计算使用最少使用置换算法时的命中率
void FIFO(int total_pf) /*先进先出页面置换算法*
您可能关注的文档
- 内部竞聘自荐信.doc
- 军体拳16动作名称.doc
- 农村学校教师周转宿舍规划.doc
- 冰淇淋场分析报告.doc
- 冰与火之歌读后感.doc
- 减肥必备:运动+食物热量表精简完整打印版本.doc
- 凯特摆测量重力加速度试验报告.doc
- 出口食品化妆品申报表.doc
- 出游必备物品清单表格版.doc
- 减肥一定不能吃的14种食物.doc
- 大模型及AI应用专题:Gemini 3.0 Nano密集发布,从谷歌AI体系看应用叙事.docx
- 宏观深度报告:超万亿美元贸易顺差流向哪里.pdf
- 肝原代细胞库的建立及肝脏自组装类器官疾病模型构建.pdf
- 全球供应链促进报告及指数矩阵.pdf
- 抖音有你真好我的上班搭子IP营销.pdf
- 2025财年加蓬国家意见调查报告2025.12.docx
- 2025年中国网文IP短剧开发价值报告.pptx
- 香樟公馆卢浮魅影国庆节晚宴活动方案.pptx
- 某县委政法委书记在全县政法综治工作会议上的发言提纲汇编(5篇).docx
- 某县民族团结进步创建经验材料:以“五个一”创建模式为抓手+争创全国民族团结进步示范县.docx
最近下载
- 颅内动脉瘤围手术期护理ppt课件.pptx VIP
- 国家开放大学土木工程本科-理工英语4--边学边练uint1-8.docx VIP
- DB22T 370-2014 建筑逃生缓降器设置技术规范-吉林省地方标准.pdf VIP
- 食品微生物学期末考试复习题及参考答案专升本.pdf VIP
- 2025年天猫《企业购专属客服认证》考试题库.docx VIP
- 《社会单位灭火和应急疏散预案编制及实施导则GBT 38315-2019》知识培训.pptx VIP
- 教师个人参与校外媒体活动报备表.docx VIP
- 机组2009年C修文件包(脱硫系统).doc VIP
- 《食品微生物学》期末考试复习题库汇总(含答案).docx VIP
- 国家建筑标准设计图集 23S519小型排水构筑物图集.pdf VIP
原创力文档


文档评论(0)