操作系统课程设计--内存FIFO,LRU页面置换算法设计.docVIP

操作系统课程设计--内存FIFO,LRU页面置换算法设计.doc

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
漳州师范学院 操作系统课程设计 内存FIFO、LRU页面 置换算法设计 姓 名: 学 号: 080811151 系 别: 计算机科学与工程系 专 业: 计算机工程 年 级: 08 级 指导教师: 2011年5月18日 一、课程设计项目介绍(含项目介绍及设计目的) 1.实验目的: 1.1通过这些算法的设计,深入理解虚拟存储器管理的原理; 1.2理解内存分页管理策略,以及页面与物理块之间的关系; 1.3掌握内存调页策略; 1.4理解常用的页面置换算法,如LRU、FIFO等置换算法,并选取LRU、FIFO算法模拟实现; 1.5通过统计比较算法的运行结果,了解各种置换算法的命中率高低,以加深对算法本身的认识。 2.实验项目介绍: 项目程序是用C语言实现LRU、FIFO页面置换算法,可运行在VC,C-FREE等编译环境下。本程序是在假设系统采用固定分配局部置换策略的基础上,来模拟内存的调页策略和置换算法。FIFO算法主要是考虑页面进入内存的时间长短,当缺页时把进入最久的页面置换掉;LRU算法以最近的过去作为最近的将来的参考,当产生缺页时,把最近最久未使用的页面置换掉。由于两个算法的相似性,所以进行统一处理,并加以区分。 二、总体设计(含系统的总体结构、原理框图或各模块介绍等) 1.确定LRU、FIFO算法中的数据结构 定义了一个结构体struct page{int pagenum; int pagetime;}; (pagenum为页面号码,pagetime为进入时间或者上次使用的时间) 来模拟内存的页面; 用page定义一个结构体数组p_age[10],表示可供使用的内存页面为10;定义一个整形数组int b[N]用来存放要访问的内存页面串,串的长度不要超过N,本程序N=100。 定义整形变量pagecount,num,time分别表示要申请的内存页数和要访问的内存页面串的长度;整形变量time用来表示时间,初始化为1,当p_age[i]页面进入时,p_age[i].pagetime=time++,此后每进入一个页面,或者更新一个页面,都把time赋给该内存页面的时间对象,然后自加1。页面的时间对象pagetime最大的那个页面是刚访问过或者刚进入的,pagetime最小的那个页面当产生缺页时将被替换掉; 变量misspage,missrate分别用来记录缺页数和缺页率; 变量flag用来标记要访问的页面是否在内存中,label用来标记已在内存中且pagetime最小的页面; FIFO[],LRU[]数组用来记录每一次执行算法的缺页率。 2.核心算法的实现 申请的内存页数为pagecount,p_age[i]为内存中页面,b[]为输入的页面串,num为b[]的长度; (1)初始化内存页面 (2)FIFO算法 从i=0开始逐个调入页面,查找b[]页面串第i个页面是否已经存在在内存当中,如果已经存在则用flag=1来做标记,i++并开始下个循环;如果不存在则flag=0,并查找已在内存中p_age[k]页面的成员pagetime最小的页面,并用label=k标记,查找到之后用b[i] 页面替换p_age[label],并且p_age[lable].pagetime=time++;继续循环,直到i=num,执行完之后输出缺页数和缺页率。 (3)LRU算法 从i=0开始逐个调入页面,查找b[]页面串第i个页面是否已经存在在内存当中,如果已经存在则用flag=1来做标记,并更新该内存页面的pagetime(访问时间)对象,i++开始下个循环;如果不存在则flag=0,并查找已在内存中p_age[k]页面的成员pagetime最小的页面,并用label=k标记,查找到之后用b[i] 页面替换p_age[label], 并且p_age[lable].pagetime=time++;继续循环,直到i=num,执行完之后输出缺页数和缺页率。 3.程序结构图 三、详细设计(含主要的数据结构、程序流程图、关键代码段及注释等) Y Y N Y N

文档评论(0)

beifanglei + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档