ImageVerifierCode 换一换
格式:DOC , 页数:21 ,大小:266.50KB ,
资源ID:9630266      下载积分:8 金币
验证码下载
登录下载
邮箱/手机:
图形码:
验证码: 获取验证码
温馨提示:
支付成功后,系统会自动生成账号(用户名为邮箱或者手机号,密码是验证码),方便下次登录下载和查询订单;
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

开通VIP
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.zixin.com.cn/docdown/9630266.html】到电脑端继续下载(重复下载【60天内】不扣币)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

开通VIP折扣优惠下载文档

            查看会员权益                  [ 下载后找不到文档?]

填表反馈(24小时):  下载求助     关注领币    退款申请

开具发票请登录PC端进行申请


权利声明

1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前可先查看【教您几个在下载文档中可以更好的避免被坑】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时联系平台进行协调解决,联系【微信客服】、【QQ客服】,若有其他问题请点击或扫码反馈【服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【版权申诉】”,意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:4009-655-100;投诉/维权电话:18658249818。

注意事项

本文(设计一个虚拟存储区和内存工作区编程序演示下述算法的具体实现过程并计算访问命中率剖析.doc)为本站上传会员【可****】主动上传,咨信网仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知咨信网(发送邮件至1219186828@qq.com、拔打电话4009-655-100或【 微信客服】、【 QQ客服】),核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载【60天内】不扣币。 服务填表

设计一个虚拟存储区和内存工作区编程序演示下述算法的具体实现过程并计算访问命中率剖析.doc

1、 齐齐哈尔大学 操作系统课程综合实践 题目: 主界面以灵活选择某算法 班级:    计本093       姓名:   赵明秋       学号:  2009021114      指导教师: 韩金库     2008年 12 月 主界面以灵活选择某算法实验 摘要: 计算机应用专业的学生全面了解和掌握系统软件,一般软件设计方法和技术的必不可少的综合课程,也是了解计算机硬件和软件如何衔接的必经之路。 我觉得此次实验最大的亮点以及不同于别人的地方就是将三种页面置换算法按照课本上老

2、师讲的方式直观简便的输出 ,在采用输出算法时,我摒弃了常人所用的一维数组输出法,而别出心裁的采用了二维数组的输出算法,模拟了内存的物理块,清晰直观的表达了页面是如何在外存中被调入内存中的,以及各页面在调入过程中是否命中或在置换时又置换了内存中哪个页面。在软件工程的角度来看,我的系统具有高内聚低耦合的优点,即各种算法之间,并不影响彼此的函数调用,而在各算法的内部,内聚度很高。 关键词:设计原理, 设计方案, 流程图,源代码,测试结果,结束语,参考文献 课题运行环境 操作系统:Windows XP 编程环境:Microsoft Visual C++6.0 1.1 实验

3、内容: 通过模拟实现请求页式存储管理的几种基本页面置换算法,了解虚拟存储技术的特点,掌握虚拟存储请求页式存储管理中几种基本页面置换算法的基本思想和实现过程,并比较它们的效率。熟悉虚拟存储管理的各种液面置换算法,并辨析恶魔你程序实现请求页式存储管理的页面置换算法。 设计一个虚拟存储区和内存工作区,编程序演示下述算法的具体实现过程,并计算访问命中率。 设计要求: 主界面以灵活选择某算法,且以下算法都要实现 1、先进先出算法(FIFO) 2、最近最久未使用算法(LRU) 3、最佳置换算法(OPT) 2.1 运行环境 1)操作系统:Windows XP 2)编程环

4、境:Microsoft Visual C++6.0 3.1 设计原理: 3.1.1 先进先出算法(FIFO) 最简单的页面置换算法是先入先出(FIFO)法。这种算法的实质是,总是选择在主存中停留时间最长(即最老)的一页置换,即先进入内存的页,先退出内存。理由是:最早调入内存的页,其不再被使用的可能性比刚调入内存的可能性大。建立一个FIFO队列,收容所有在内存中的页。被置换页面总是在队列头上进行。当一个页面被放入内存时,就把它插在队尾上。这种算法只是在按线性顺序访问地址空间时才是理想的,否则效率不高。因为那些常被访问的页,往往在主存中也停留得最久,结果它们因变“老”而不得不被置换出去

5、 FIFO的另一个缺点是,它有一种异常现象,即在增加存储块的情况下,反而使缺页中断率增加了。当然,导致这种异常现象的页面走向实际上是很少见的。 该算法将所有使用的内存页面构成一个循环列队,每次置换时将队列中的队首唤出,队首指针后移一位即可,算法容易实现牡丹石最先进入内存的野末必将来就不用再到,甚至可能很快就会用到,所以不能保证有效的缺页率,算法性能较差。 3.2.2 最近最久未使用算法(LRU) FIFO算法和OPT算法之间的主要差别是,FIFO算法利用页面进入内存后的时间长短作为置换依据,而OPT算法的依据是将来使用页面的时间。如果以最近的过去作为不久将来的近似,那么就可以把过

6、去最长一段时间里不曾被使用的页面置换掉。它的实质是,当需要置换一页时,选择在最近一段时间里最久没有使用过的页面予以置换。这种算法就称为最久未使用算法(Least Recently Used,LRU)。 LRU算法是与每个页面最后使用的时间有关的。当必须置换一个页面时,LRU算法选择过去一段时间里最久未被使用的页面。 LRU算法是经常采用的页面置换算法,并被认为是相当好的,但是存在如何实现它的问题。LRU算法需要实际硬件的支持。其问题是怎么确定最后使用时间的顺序,对此有两种可行的办法: (1)计数器。最简单的情况是使每个页表项对应一个使用时间字段,并给CPU增加一个逻辑时钟或

7、计数器。每次存储访问,该时钟都加1。每当访问一个页面时,时钟寄存器的内容就被复制到相应页表项的使用时间字段中。这样我们就可以始终保留着每个页面最后访问的“时间”。在置换页面时,选择该时间值最小的页面。这样做,不仅要查页表,而且当页表改变时(因CPU调度)要维护这个页表中的时间,还要考虑到时钟值溢出的问题。 (2)栈。用一个栈保留页号。每当访问一个页面时,就把它从栈中取出放在栈顶上。这样一来,栈顶总是放有目前使用最多的页,而栈底放着目前最少使用的页。由于要从栈的中间移走一项,所以要用具有头尾指针的双向链连起来。在最坏的情况下,移走一页并把它放在栈顶上需要改动6个指针。每次修改都要有开销,

8、但需要置换哪个页面却可直接得到,用不着查找,因为尾指针指向栈底,其中有被置换页。 因实现LRU算法必须有大量硬件支持,还需要一定的软件开销。所以实际实现的都是一种简单有效的LRU近似算法。 一种LRU近似算法是最近未使用算法(Not Recently Used,NUR)。它在存储分块表的每一表项中增加一个引用位,操作系统定期地将它们置为0。当某一页被访问时,由硬件将该位置1。过一段时间后,通过检查这些位可以确定哪些页使用过,哪些页自上次置0后还未使用过。就可把该位是0的页淘汰出去,因为在最近一段时间里它未被访问过。 3.3.3 最佳置换算法(OPT) 最优置换(Optimal Re

9、placement)是在理论上提出的一种算法。其实质是:当调入新的一页而必须预先置换某个老页时,所选择的老页应是将来不再被使用,或者是在最远的将来才被访问。采用这种页面置换算法,保证有最少的缺页率。但是最优页面置换算法的实现是困难的,因为它需要人们预先就知道一个进程整个运行过程中页面走向的全部情况。不过,这个算法可用来衡量(如通过模拟实验分析或理论分析)其他算法的优劣。 该算法能保证有最低的缺页率,所以称为最佳置换算法,但是该算法紧紧是一种理想状况下的算法,因为在进程实际运行过程中,将来会执行到那儿页是不可预知的,所以无法选择该置换那个页出去。因此,本算法在实际中无法使用,只能作为一种标准来

10、衡量其他算法的性能 4.1 设计方案 1)主界面: 设置页面产生算法选择界面和页面置换算法选择界面; 2)子界面: 页面产生算法分为两个界面,分别是随机产生算法和自己输入产生算法。 页面置换算法分为三个子界面,分别是先进先出算法界面、最近最久未使用算法界面、最佳置换算法界面。 5.1 流程图 5.1.1主流程图 图(1) 5.1.2 FIFO函数流程图: 图(2) 5.1.3 LRU函数流程图:

11、图(4) 5.1.4 OPT函数流程图: 图(5) 6.源代码 6.1 程序代码 #include #include #include #define Bsize 3 #define Psize 12 #include using namespace std; int QString[Psize]; int Num=0; struct pageInfor { int content; int timer; }; class YZ_replace { public

12、 YZ_replace(); ~YZ_replace(); int findSpace(); int findExist(int curpage); int findReplace(); void FIFO(); void OPT(); void BlockClear(); void initia1(int string[]); pageInfor *block; pageInfor *page; int memory_state[Bsize][Psize]; int s; private: }; v

13、oid P_String(int QString[]) { int i; srand((unsigned)time(NULL)); for(i=0;i

14、ndl; } YZ_replace::YZ_replace() { s=0; block = new pageInfor[Bsize]; for(int i=0; i

15、 page[i].content = QString[i]; page[i].timer = 0; } for(i=0;i

16、t YZ_replace::findExist(int curpage) { for(int i=0; i= block[pos].timer) pos = i; return pos; }

17、 void YZ_replace::FIFO() { int exist,space,position ; for(int i=0; i

18、1) { for(int b=0; b

19、 position = findReplace(); block[position] = page[i]; memory_state[position][i]=block[position].content; } } for(int j=0; j

20、 = 0; } } typedef struct page { int num; int time; }Page; Page b[Bsize]; Page call[Bsize]; int c[Bsize][Psize]; int queue[100]; int K; void InitL(Page *b,int c[Bsize][Psize]) { int i,j; for(i=0;i

21、ize-i-1; } for(i=0;imax) { max=b[i].time; tag=i; } } return tag; } int Equation(int fold,Page *b) { int i; for(i=

22、0;i=0) { b[val].time=0; for(i=0;i

23、b[val].num=fold; b[val].time=0; for(i=0;i

24、memory_state[b][i-1]; } s++; } else { space = findSpace(); if(space != -1) { for(int b=0; b

25、{ for(int k=0; k

26、 } position = findReplace(); block[position] = page[i]; memory_state[position][i]=block[position].content; } } } } int decide(string str) { for(int i=0;i'9') { return 0; break; } } retur

27、n i; } int trans(string str) { int sum=0; for(int i=0;i>str; a=decide(str); while(a==0) { cout<<"输入错误,请重新输入!"<>str; a=decide(st

28、r); } d=trans(str); return d; } void Put() { cout<<"请选择产生页面的方法 a:随机产生 b:输入产生"<>F; while(F!='a'&&F!='b') { cout<<"输入错误,请重新输入:"; cin>>F; } if(F=='a') P_String(QString) ; if(F=='b') { cout<<"请输入各页面号:"<

29、int i=0;i

30、"<FIFO算法 <2>LRU算法 <3>OPT算法 <0>退出"<>select; while(select!

31、'0'&&select!='1'&&select!='2'&&select!='3') { cout<<"您的输入无效,请重新输入:"<>select; } if(select=='0') { cout<<"您选择的是菜单<0>"<"<

32、 cout<<"FIFO算法状态:"<

33、cout<

34、 int i,j; K=-1; InitL(b, c); for(i=0;i"<

35、 cout<<"LRU算法状态:"<

36、 cout<<"------------------------------------------"<"<

37、1(QString); test3.OPT(); test3.BlockClear(); cout<<"------------------------------------------"<

38、ndl; } cout<<"------------------------------------------"<

39、 图(7.2) 分析:页面产生的方法有两种选择,分别是随机产生和自己输入产生,选择菜单的时候有对异常输入的处理,如果输入错误,有错误提示,当输入正确菜单的时候,选择a,自动产生页面走向,如果选择b,自己可以任意输入,如果输入错误,有错误提示。 6.2 应用算法选择测试 图(7.3) 分析:选择算法时,有异常处理,即如果输入错误,有错误提示。如果选择菜单1,即选择了FIFO算法,展示此算法的置换状态并显示命中率。置换状态以二维数组的形式输出,既直观又清晰。

40、 图(7.4) 分析:算法一进行完以后,界面自动跳到应用算法的选择界面,即可以再次选择置换算法,选择菜单2,即选择了LRU算法,展示此算法的置换状态并显示命中率,可以和第一个算法进行对比,找出两种算法的不同。 图(7.5) 分析:算法二进行完以后,界面自动跳到应用算法的选择界面,即可以再次选择置换算法,选择菜单3,即选择了OPT算法,展示此算法的置换状态并显示命中率,可以和第二个算法进行对比,找出两种算法的不同。 图(7.6) 分析:算法二

41、进行完以后,界面自动跳到应用算法的选择界面,即可以再次选择置换算法,选择菜单3,即选择了OPT算法,展示此算法的置换状态并显示命中率,可以和第二个算法进行对比,找出两种算法的不同。 8.结束语 为期两周的操作系统课设在不断的探索、尝试、成功中结束了。现在,站在成功地峰顶,回顾着走过的一路,真是什么感觉都有,枯燥、失败、劳累、迷茫、喜悦,应该说,我的设计体会相当深刻。 首先,谈谈本系统的不足: 我设计的页面值换算法里,页面个数和内存个数是一个定数,在这一点上没有实现与操作员的交互,即页面数和内存个数并不能手动输入,我设计的系统在界面上并没有太大的优化,没有实现选择算法后可以重新选择页

42、面产生的算法,重新进行页面置换的选择。总体上来说,这两方面是本系统可以改进的地方,虽然我的课设已经验收,但是我在验收完成后,继续完善了我的整个界面并改进了系统的不足之处,以达到系统的完整性,简洁性,交互性。 其次,谈谈本系统特色、新的发明、创造等 最后,在整体上自我评价一下我的系统: 第一,在功能上,它完全实现了各种页面置换算法的模拟;第二,在界面设计上,新颖独特,独树一帜,采用了二维数组的输出方法了;第三,异常处理面面俱到,不需要担心因为输入错误而出现乱码,甚至重新执行。 在此课设期间我为自己总结了四句话:鄙视平庸和碌碌无为,敢于主张自己并坚持不懈,用于忍耐寂寞、枯燥和劳累,善于探求登峰捷径且百折不挠。 最最后,也是我最想说的话,衷心地感谢李新荣老师对我的悉心指导和最大的信任。 9.1 参考文献 [1] 《计算机操作系统》 哲凤屏 汤子瀛 西安电子科技大学出版社.2011年2月 [2]《C语言程序设计教程》(第三版)谭浩强 张基温 高级教育出版社.2008年4月 [3]《程序设计基础》(第二版)吴文虎 清华大学出版社.2010年2月 [4]《C++程序设计》 刘娜娜 北京航空大学出版社.2008年4月

移动网页_全站_页脚广告1

关于我们      便捷服务       自信AI       AI导航        抽奖活动

©2010-2025 宁波自信网络信息技术有限公司  版权所有

客服电话:4009-655-100  投诉/维权电话:18658249818

gongan.png浙公网安备33021202000488号   

icp.png浙ICP备2021020529号-1  |  浙B2-20240490  

关注我们 :微信公众号    抖音    微博    LOFTER 

客服