电子文档交易市场
安卓APP | ios版本
电子文档交易市场
安卓APP | ios版本

操作系统存储管理实验报告课案

9页
  • 卖家[上传人]:206****923
  • 文档编号:91101141
  • 上传时间:2019-06-22
  • 文档格式:DOC
  • 文档大小:105.50KB
  • / 9 举报 版权申诉 马上下载
  • 文本预览
  • 下载提示
  • 常见问题
    • 1、 河南师范大学计算机与信息技术学院实验报告实验五 存储管理一、实验目的 1 、加深对操作系统存储管理的理解 2 、能过模似页面调试算法,加深理解操作系统对内存的高度管理 2、 总的设计思想、环境语言、工具等总的设计思想:1、编写函数计算并输出下述各种算法的命中率 OPT页面置换算法OPT所选择被淘汰的页面是已调入内存,且在以后永不使用的,或是在最长时间内不再被访问的页面。因此如何找出这样的页面是该算法的关键。可为每个页面设置一个步长变量,其初值为一足够大的数,对于不在内存的页面,将其值重置为零,对于位于内存的页面,其值重置为当前访问页面与之后首次出现该页面时两者之间的距离,因此该值越大表示该页是在最长时间内不再被访问的页面,可以选择其作为换出页面。 FIFO页面置换算法FIFO总是选择最先进入内存的页面予以淘汰,因此可设置一个先进先出的忙页帧队列,新调入内存的页面挂在该队列的尾部,而当无空闲页帧时,可从该队列首部取下一个页帧作为空闲页帧,进而调入所需页面。 LRU页面置换算法LRU是根据页面调入内存后的使用情况进行决策的,它利用“最近的过去”作为“最近的将来”的近似,选择最近最久未使用

      2、的页面予以淘汰。该算法主要借助于页面结构中的访问时间time来实现,time记录了一个页面上次的访问时间,因此,当须淘汰一个页面时,选择处于内存的页面中其time值最小的页面,即最近最久未使用的页面予以淘汰。 LFU页面置换算法LFU要求为每个页面配置一个计数器(即页面结构中的counter),一旦某页被访问,则将其计数器的值加1,在需要选择一页置换时,则将选择其计数器值最小的页面,即内存中访问次数最少的页面进行淘汰。 NUR页面置换算法NUR要求为每个页面设置一位访问位(该访问位仍可使用页面结构中的counter表示),当某页被访问时,其访问位counter置为1。需要进行页面置换时,置换算法从替换指针开始(初始时指向第一个页面)顺序检查处于内存中的各个页面,如果其访问位为0,就选择该页换出,否则替换指针下移继续向下查找。如果内存中的所有页面扫描完毕未找到访问位为0的页面,则将替换指针重新指向第一个页面,同时将内存中所有页面的访问位置0,当开始下一轮扫描时,便一定能找到counter为0的页面。2、 在主函数中生成要求的指令序列,并将其转换成页地址流;在不同的内存容量下调用上述函数使

      3、其计算并输出相应的命中率。环境语言:Linux下的GNU 编译环境三、数据结构与模块说明程序中用到的数据结构、类型定义及主要的函数原型如下:1、 数据结构(1) 页面结构 typedef struct int pn, pfn, counter, time; pl_type ;pl_type pltotal_vp;其中pn为页面号(页号),pfn为页帧号(物理块号),counter为一个周期内访问该页面的次数,time为访问时间;pltotal_vp为页面结构数组,由于共有320条指令,每页可装入10条指令,因此虚页长total_vp的值为32。(2)页帧控制结构struct pfc_struct int pn, pfn;struct pfc_struct *next;typedef struct pfc_struct pfc_type;pfc_type pfctotal_vp, *freepf_head, *busypf_head, *busypf_tail;其中pfctotal_vp定义用户进程的页帧控制结构数组,在该实验中,用户内存工作区是动态变化的,最多可达到用户进程的虚页数目,

      4、即32个物理块。*freepf_head为空闲页帧头的指针*busypf_head为忙页帧头的指针*busypf_tail忙页帧尾的指针2、 变量定义(1) int atotal_instruction: 指令流数组(2) int diseffect: 页面失效次数(3) int pagetotal_instruction: 每条指令所属页面号(4) int offsettotal_instruction: 每页装入10条指令后取模运算得出的页内偏移地址(5) int total_pf: 用户进程的内存页帧数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、久未使用页面置换算法时的命中率(5) void LFU(int): 计算使用最少使用置换算法时的命中率(6) void NUR(int): 计算使用最近未使用置换算法时的命中率四、主要算法的设计与实现void FIFO(int total_pf) /*先进先出页面置换算法*/ int i,j; pfc_type *p; initialize(total_pf); busypf_head=busypf_tail=NULL;for(i=0;inext;plbusypf_head-pn.pfn=INVALID; /将忙页帧队首页面作为换出页面freepf_head=busypf_head; freepf_head-next=NULL;busypf_head=p; /忙页帧头指针后移p=freepf_head-next; /有空闲页帧freepf_head-next=NULL;freepf_head-pn=pagei; /* 将所需页面调入空闲页帧 */plpagei.pfn=freepf_head-pfn;if(busypf_tail=NULL) /* 若忙页帧队列为空,则将其头尾指针都指向

      6、刚调入页面所在的页帧 */busypf_head=busypf_tail=freepf_head;else /否则,将刚调入页面所在的页帧挂在忙页帧队列尾部busypf_tail-next=freepf_head;busypf_tail=freepf_head;freepf_head=p; /空闲页帧头指针后移 printf(FIFO:%6.4f ,1-(float)diseffect/320);void LRU(int total_pf) /*最近最久未使用页面置换算法*/ int i,j; int min,minj,present_time; initialize(total_pf); present_time=0;for(i=0;itotal_instruction;i+) if(plpagei.pfn=INVALID) /*页面失效*/diseffect+;if(freepf_head=NULL) /*无空闲页帧*/min=32767;for(j=0;jplj.time & plj.pfn!=INVALID)min=plj.time;minj=j;freepf_head=&pf

      7、cplminj.pfn; /腾出一个单元plminj.pfn=INVALID;plminj.time=-1;freepf_head-next=NULL;plpagei.pfn=freepf_head-pfn; /有空闲页面,改为有效plpagei.time=present_time; /修改页面的访问时间freepf_head=freepf_head-next; /减少一个free 页面elseplpagei.time=present_time; /命中则修改该单元的访问时间present_time+; printf(LRU:%6.4f ,1-(float)diseffect/320);void NUR(int total_pf)/* 最近未使用页面置换算法 */int i,j,dp,cont_flag,old_dp; initialize(total_pf); dp=0;for(i=0;itotal_instruction;i+) if(plpagei.pfn=INVALID) /*页面失效*/ diseffect+; if(freepf_head=NULL) /*无空闲页帧*/ cont_flag=TRUE;old_dp=dp;while(cont_flag)if(pldp.counter=0&pldp.pfn!=INVALID)cont_flag=FALSE; /找到位于内存且未被访问的页面 elsedp+;if(dp=total_vp) dp=0; /将替换指针重新指向第一个页面if(dp=old_dp)/* 若内存中所有页面扫描完毕未找到访问位为0的页面,将内存中所有页面的访问位置0 */for(j=0;jnext=NULL; plpagei.pfn=freepf_head-pfn; /有空闲页面,改为有效 fr

      《操作系统存储管理实验报告课案》由会员206****923分享,可在线阅读,更多相关《操作系统存储管理实验报告课案》请在金锄头文库上搜索。

      点击阅读更多内容
    最新标签
    发车时刻表 长途客运 入党志愿书填写模板精品 庆祝建党101周年多体裁诗歌朗诵素材汇编10篇唯一微庆祝 智能家居系统本科论文 心得感悟 雁楠中学 20230513224122 2022 公安主题党日 部编版四年级第三单元综合性学习课件 机关事务中心2022年全面依法治区工作总结及来年工作安排 入党积极分子自我推荐 世界水日ppt 关于构建更高水平的全民健身公共服务体系的意见 空气单元分析 哈里德课件 2022年乡村振兴驻村工作计划 空气教材分析 五年级下册科学教材分析 退役军人事务局季度工作总结 集装箱房合同 2021年财务报表 2022年继续教育公需课 2022年公需课 2022年日历每月一张 名词性从句在写作中的应用 局域网技术与局域网组建 施工网格 薪资体系 运维实施方案 硫酸安全技术 柔韧训练 既有居住建筑节能改造技术规程 建筑工地疫情防控 大型工程技术风险 磷酸二氢钾 2022年小学三年级语文下册教学总结例文 少儿美术-小花 2022年环保倡议书模板六篇 2022年监理辞职报告精选 2022年畅想未来记叙文精品 企业信息化建设与管理课程实验指导书范本 草房子读后感-第1篇 小数乘整数教学PPT课件人教版五年级数学上册 2022年教师个人工作计划范本-工作计划 国学小名士经典诵读电视大赛观后感诵读经典传承美德 医疗质量管理制度 2 2022年小学体育教师学期工作总结 2022年家长会心得体会集合15篇
    关于金锄头网 - 版权申诉 - 免责声明 - 诚邀英才 - 联系我们
    手机版 | 川公网安备 51140202000112号 | 经营许可证(蜀ICP备13022795号)
    ©2008-2016 by Sichuan Goldhoe Inc. All Rights Reserved.