欢迎来到淘文阁 - 分享文档赚钱的网站! | 帮助中心 好文档才是您的得力助手!
淘文阁 - 分享文档赚钱的网站
全部分类
  • 研究报告>
  • 管理文献>
  • 标准材料>
  • 技术资料>
  • 教育专区>
  • 应用文书>
  • 生活休闲>
  • 考试试题>
  • pptx模板>
  • 工商注册>
  • 期刊短文>
  • 图片设计>
  • ImageVerifierCode 换一换

    操作系统页面置换算法.doc

    • 资源ID:36174279       资源大小:223KB        全文页数:15页
    • 资源格式: DOC        下载积分:15金币
    快捷下载 游客一键下载
    会员登录下载
    微信登录下载
    三方登录下载: 微信开放平台登录   QQ登录  
    二维码
    微信扫一扫登录
    下载资源需要15金币
    邮箱/手机:
    温馨提示:
    快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如填写123,账号就是123,密码也是123。
    支付方式: 支付宝    微信支付   
    验证码:   换一换

     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    操作系统页面置换算法.doc

    操作系统页面置换算法 操作系统课程设计报告院 (系): 信息与数学学院 专 业: 信息与计算科学 姓 名: 张三 班 级: 信计11402 学 号: 12 29 14 题 目: 页面置换算法 指导教师: 孙庆生 2017年5月27日一、课程设计目的Linux操作系统课程设计是在学完操作系统课程之后的实践教学环节,是复习和检验所学课程的重要手段。通过实验环节,加深学生对操作系统基本原理和工作过程的理解,提高学生独立分析问题、解决问题的能力,增强学生的动手能力。二、课程设计的任务和要求由于具体的操作系统相当复杂,不可能对所有管理系统进行详细地分析。因此,选择了操作系统中最重要的管理之一存储器管理,作为本设计的任务。页面置换算法是虚拟存储管理实现的关键,要求在充分理解内存页面调度机制的基础上,模拟实现OPT、FIFO、LRU几种经典页面置换算法,比较各种置换算法的效率及优缺点,从而了解虚拟存储实现的过程。具体任务如下:1) 分析设计内容,给出解决方案要说明设计实现的原理;采用的数据结构:定义为进程分配的物理块;定义进程运行所需访问的页面号;定义页的结构;2)模拟三种页面置换算法;3)比较各种算法的优劣。4)对程序的每一部分要有详细的设计分析说明。5)源代码格式要规范。6) 设计合适的测试用例,对得到的运行结果要有分析。任务要求:Linux平台下实现(Windows+ VMware+ Ubuntu) 三、课程的详细设计1)系统设计在进程运行过程中,若其所要访问的页面不在内存而需把它们调入内存,但内存已无空闲空间时,为了保证该进程能正常运行,系统必须从内存中调出一页程序或数据,送磁盘的对换区中。但应将哪 个页面调出,须根据一定的算法来确定。通常,把选择换出页面的算法称为页面置换算法。 一个好的页面置换算法,应具有较低的页面更换频率。从理论上讲,应将那些以后不再会访问的页面换出,或将那些在较长时间内不会再访问的页面调出。2)主程序流程图输入页面序列输入物理块数调用各种置换算法,OPT,LRU,FIFO页面置换算法计算缺页次数和缺页率结束开始主流程图3)先进先出(FIFO)页面置换算法算法的基本思想:该算法总是淘汰最先进入内存的页面,即选择在内存中驻留时间最久的页面予以淘汰。该算法实现简单只需把一个进程已调入内存的页面,按先后次序存入一个时间数组,并将其中时间值最大的页面进行淘汰,并替换入新的页面就可以实现。算法流程图: 入口初始化数据i指向下一个页面页面是否存在物理块是否有空闲选择最先进入的页面作为淘汰页计算缺页率,并输出数据 结束输出当前页,i+将页面放到空闲的物理块处i<页面长度YYYNNNFIFO置换算法4)最佳页面置换置换算法(OPT)算法的基本思想:其所选择的被淘汰页面,将是永不使用的,或者是在最长时间内不再被访问的页面。可保证获得最低的缺页率。但由于人们目前还无法预知一个进程在内存的若干个页面中,哪一个页面是未来最长时间内不再被访问的,因而该算法也是无法实现的。但是可利用该算法去评价其它算法。算法流程图: 入口初始化数据i指向下一个页面页面是否存在物理块是否有空闲选择以后最长时间内(未来)不在被访问的页面作为淘汰页计算缺页率,并输出数据 结束输出当前页, i+将页面放到空闲的物理块处i<页面长度YYYNNNOPT页面置换算法5)最近最久未使用页面置换算法LRU算法的基本思想:当需要淘汰某一页时,选择离当前时间最近的一段时间内最久没有使用过的页先淘汰。该算法的主要出发点是,如果某页被访问了,则它可能马上还被访问。或者反过来说,如果某页很长时间未被访问,则它在最近一段时间不会被访问。算法流程图: 入口初始化数据i指向下一个页面页面是否存在物理块是否有空闲选择最近最久未使用的页面作为淘汰页计算缺页率,并输出数据 结束输出当前页,i+将页面放到空闲的物理块处i<页面长度YYYNNNLRU页面置换算法四、源程序代码#include"stdio.h"#include"malloc.h"#define N 20#define num 3/*进程分配物理块数目*/int AN=7,0,1,2,0,3,0,4,2,3,0,3,2,1,2,0,1,7,0,1;typedef struct page/*页表映像*/ int address; /*页面地址*/ struct page *next; page;struct page *head,*run,*rear;void initial() /*进程分配物理块*/ int i=1; page *p,*q; head=(page *)malloc(sizeof(page); p=head; for(i=1; i<=num; i+) q=(page *)malloc(sizeof(page); p->next=q; q->address=-1; q->next=NULL; p=q; rear=p;void print()page *p=head->next;while(p)if(p->address!=-1)/*避免输出-1*/printf("%dt",p->address);p=p->next;printf("n");int search(int n)/*判断链表中是否有n*/ page *p; int i=0; p=head; while(p->next) if(p->next->address=n) printf("Get it at the page %dn",i+1); run=p; return 1; p=p->next; i+; return 0;void changeOPT(int n,int position) int i; int total=0; int flag=1;/*默认链表填满*/ int distancenum;/*用于存放距离*/ int MAX; int order=0; page *p,*q; p=head->next; q=head->next; for(i=0; i<num; i+)/*初始化距离*/ distancei=100; i=0; while(p)/*判断链表中是否填满*/ if(p->address=-1) flag=0; break; p=p->next; i+; if(!flag)/*链表没有填满的情况*/ p->address=n; printf("Change the page %dn",i+1); else/*链表已经填满的情况*/ while(q)/*计算距离*/ for(i=position+1; i<N; i+) if(q->address=Ai) distancetotal=i-position; break; total+; q=q->next; MAX=distance0; for(i=0; i<num; i+)/*计算最大距离*/ if(distancei>MAX) MAX=distancei; order=i;/*记录待替换的页面的位置*/ printf("Change the page %dn",order+1); i=0; p=head->next; while(p)/*页面替换*/ if(i=order) p->address=n; i+; p=p->next; void changeFIFO(int n,int position) int i=0; int flag=1;/默认队列已满 page *p,*delect; p=head->next; while(p) if(p->address=-1)/队列未满 flag=0; p->address=n; printf("Change the page %dn",i+1); break; p=p->next; i+; if(flag)/队列已满 delect=head->next; delect->address=n; head->next=delect->next; printf("Delect from the head, and add new to the end.n"); rear->next=delect; rear=delect; rear->next=NULL; void changeLRU(int n,int position) int i; int total=0; int flag=1;/*默认为已满*/ int distancenum; int MAX; int order=0; page *p,*q; p=head->next; q=head->next; for(i=0; i<num; i+) distancei=100; i=0; while(p)/*判断链表是否已满*/ if(p->address=-1) flag=0; break; p=p->next; i+; if(!flag)/*链表没有满的情况*/ p->address=n; printf("Change the page %dn",i+1); else/*链表已满的情况*/ while(q) for(i=position-1; i>=0; i-)/*向前计算距离*/ if(q->address=Ai) distancetotal=position-i; break; total+; q=q->next; MAX=distance0; for(i=0; i<num; i+)/*计算最远距离*/ if(distancei>MAX) MAX=distancei; order=i; printf("Change the page %dn",order+1); i=0; p=head->next; while(p)/*页面替换*/ if(i=order) p->address=n; i+; p=p->next; float OPT() int i; int lose=0; float losef; float percent; for(i=0; i<N; i+) if(search(Ai)=0) lose+; changeOPT(Ai,i); print(); losef=(float)lose; percent=1-(losef/N); return percent;float LRU() int i; int lose=0; float losef; float percent; for(i=0; i<N; i+) if(search(Ai)=0) lose+; changeLRU(Ai,i); print(); losef=(float)lose; percent=1-(losef/N); return percent;float FIFO() int i; int lose=0; float losef; float percent;page *p; for(i=0; i<N; i+) if(search(Ai)=0) lose+; changeFIFO(Ai,i); else p=run->next; run->next=p->next; rear->next=p; rear=p; rear->next=NULL; printf("Move it to end of queue.n"); print(); losef=(float)lose; percent=1-(losef/N); return percent;void main()/*主函数部分*/ float percent; int choice; printf("Select the arithmetic:n(1)OPTn(2)LRUn(3)FIFOn your choice is:"); scanf("%d",&choice);/*选择页面置换算法*/ initial();/*创建进程*/ if(choice=1)/*采用OPT算法置换*/ percent=OPT();/*计算OPT时的缺页率*/ printf("The percent of OPT is %fn",percent); else if(choice=2)/*采用LRU算法置换*/ percent=LRU();/*计算LRU时的缺页率*/ printf("The percent of LRU is %fn",percent); else if(choice=3)/*采用FIFO算法置换*/ percent=FIFO();/*计算FIFO时的缺页率*/ printf("The percent of FIFO is %fn",percent); else printf("Your choice is invalid."); 五、 调试结果显示 (1)OPT置换算法 (2)LRU置换算法 LRUFIFO置换算法15 / 15

    注意事项

    本文(操作系统页面置换算法.doc)为本站会员(叶***)主动上传,淘文阁 - 分享文档赚钱的网站仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知淘文阁 - 分享文档赚钱的网站(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    关于淘文阁 - 版权申诉 - 用户使用规则 - 积分规则 - 联系我们

    本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

    工信部备案号:黑ICP备15003705号 © 2020-2023 www.taowenge.com 淘文阁 

    收起
    展开