ImageVerifierCode 换一换
格式:DOCX , 页数:21 ,大小:864.85KB ,
资源ID:7909268      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

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

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

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(操作系统请求分页式管理.docx)为本站会员(b****6)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

操作系统请求分页式管理.docx

1、操作系统请求分页式管理课程设计题目:请求页式管理模拟实现一、需求分析请求页式管理是一种常用的虚拟存储管理技术。本设计通过请求页式存储管理中页面置换算法模拟设计,了解虚拟 存储技术的特点,掌握请求页式管理的页面置换算法。 1.设计目的1、通过模拟实现请求分页式存储管理的几种基本页面置换算法,了解虚拟存储技术的特点。2、通过页面、页表、地址转换和页面置换过程的模拟,加深对请求调页系统的原理和实现过程的理解。3、掌握虚拟存储请求页式存储管理中几种基本页面置换算法的基本思想和实现过程,并比较它们的效率。 2.设计要求通过随机数产生一个指令序列,共320条指令。指令的地址按下述原则生成: 50% 的指令

2、是顺序执行的; 25% 的指令是均匀分布在前地址部分; 25% 的指令是均匀分布在后地址部分。具体的实施方法是:在 0,319 的指令地址之间随机选取一起点 m;顺序执行一条指令;在前地址0,m+1中随机选取一条指令并执行,该指令的地址为 m; 顺序执行一条指令,其地址为 m+1;在后地址 m+2,319 中随机选取一条指令并执行 ;重复上述步骤 , 直到执行 320 次指令。将指令序列变换成为页地址流设:页面大小为 1K;用户内存容量为 4 页到 32 页 ;用户虚存容量为 32K 。在用户虚存中,按每 K 存放 10 条指令排列虚存地址,即 320 条指令在虚存中的存放方式为:第 0 条

3、第 9 条指令为第 0 页 ( 对应虚存地址为 0,9);第 10 条 第 19 条指令为第 1 页 ( 对应虚存地址为 10,19 ) ;第 310 条 第 319 条指令为第 31 页 ( 对应虚存地址为 310,319) 。按以上方式,用户指令可组成 32 页。计算并输出下述各种算法在不同内存容量下的命中率。先进先出的算法 (FIFO);最近最少使用算法 (LRR);最少访问页面算法 (LFR);最近最不经常使用算法 (NUR)。 3.解决方案(一)FIFO页面置换算法先用bool IsExit()函数判断请求页面是否在内存中,在内存中就直接运行,不在的话,就通过Simulatexy%M

4、算出先进来的页面,比如假如第6个数内存中没有,那置换时第6行第1列数一定是第一个进来的,我y的值这时候是6,然后y除以m取余,就是6除以5取余也就是1,然后将第一个置换出来,下面的就是重复上面的过程了。每次要置换时LackNum的值就会加1,最后输出页面的置换的过程,算出缺页率。(二)LRU页面置换算法先用int IsExitLRU()函数判断请求页面是否在内存中,在内存中就直接运行,不在的话,int Compare()算出需要置换的页面,这个功能的实现需要数组PageCount来实现。PageCount这个数组记录着内存里5个物理块使用情况,找出需要置换的页面的列数,然后赋值给k,再通过Si

5、mulatexk=PageOrderx语句置换,每次要置换时LackNum的值就会加1,最后输出页面的置换的过程,算出缺页率。(三)OPT页面置换算法先用int IsExitOPT()函数判断请求页面是否在内存中,在内存中就直接运行,不在的话,int Compare()2算出需要置换的页面,我将请求数后面产生的的随机数一个一个和内存中的物理块的数比较,当相等的时候,记下相等的物理块号,再做第二个循环,第二个循环比较是除了第一个记录下来的数之外的4个数,相等的时候,再记下相等的物理块号,然后再做第三个循环.第四个做完后返回10减去刚刚找到的物理块号之和。这个就是要置换的数的列号,然后置换,每次要

6、置换时LackNum的值就会加1,最后输出页面的置换的过程,算出缺页率。 4实验提示提示:A.命中率=1-页面失效次数/页地址流长度B.本实验中,页地址流长度为320,页面失效次数为每次访问相应指令时,该指令所对应的页不在内存的次数。C.关于随机数产生方法,采用TC系统提供函数RAND()和RANDOMIZE()来产生。二、概要设计 1、结构说明(一)FIFO页面置换算法在分配内存页面数小于进程页面数时,当然是最先运行的页面放入内存。这时有需要处理新的页面,则将原来内存中的页面最先进入的调出(是以称为FIFO),然后将新页面放入。以后如果再有新页面需要调入,则都按的规则进行。(二)LRU页面置

7、换算法当分配内存页面数小于进程页面数时,当然是把最先执行的页面放入内存。当需要调页面进入内存,而当前分配的内存页面全部不空闲时,选择将其中最长时间没有用到的那个页面调出,以空出内存来放置新调入的页面(称为LRU)。以后如果再有新页面需要调入,则都按的规则进行。(三)OPT页面置换算法当分配内存页面数小于进程页面数时,当然是把最先执行的页面放入内存。当需要调页面进入内存,而当前分配的内存页面全部不空闲时,选择将其中最近时间不会用到的那个页面调出,以空出内存来放置新调入的页面(称为OPT)。以后如果再有新页面需要调入,则都按的规则进行 2、数据结构及模块说明定义的变量:const int MaxN

8、um=320;/指令数const int M=5;/内存容量int PageOrderMaxNum;/页面请求int SimulateMaxNumM;/页面访问过程int PageCountM,LackNum;/PageCount用来记录LRU算法中最久未使用时间,LackNum记录缺页数float PageRate;/命中率函数说明:bool IsExit(int i) /FIFO算法中判断新的页面请求是否在内存中int IsExitLRU(int i) /LRU算法中判断新的页面请求是否在内存中int Compare() /LRU算法找出内存中需要置换出来的页面int IsExitOPT(

9、int i) /OPT算法中判断新的页面请求是否在内存中int Compare2(int i) /OPT算法找出内存中需要置换出来的页面void Init() /初始化页框void designBy() /给自己加的一个标题void OutPut() /输出void FIFO() /FIFO算法void LRU() /LRU算法void OPT() /OPT算法void YourChoice(int choice) /实现你选择哪个算法的功能 3、流程图三、详细设计主要函数设计及说明:#include#includeusing namespace std;const int MaxNum=32

10、0;/指令数const int M=5;/内存容量int PageOrderMaxNum;/页面请求int SimulateMaxNumM;/页面访问过程int PageCountM,LackNum;/PageCount用来记录LRU算法中最久未使用时间,LackNum记录缺页数float PageRate;/命中率bool IsExit(int i)/FIFO算法中判断新的页面请求是否在内存中 bool f=false; for(int j=0;jM;j+) if(Simulatei-1j=PageOrderi)/在前一次页面请求过程中寻找是否存在新的页面请求 f=true; return

11、f;int IsExitLRU(int i)/LRU算法中判断新的页面请求是否在内存中 int f=-1; for(int j=0;jM;j+) if(Simulatei-1j=PageOrderi) f=j; return f;int Compare()/LRU算法找出内存中需要置换出来的页面 int p,q; p=PageCount0; q=0; for(int i=1;iM;i+) if(pPageCounti) p=PageCounti; q=i; return q;int IsExitOPT(int i)/OPT算法中判断新的页面请求是否在内存中 int h=-1; for(int

12、j=0;jM;j+) if(Simulatei-1j=PageOrderi) h=j; return h;int Compare2(int i)/OPT算法找出内存中需要置换出来的页面 int q,n,l,m,y,j; q=-1,n=-1,m=-1,l=-1,y=-1; for(int d=i;d320;d+) for(j=0;jM;j+) if(Simulatei-1j=PageOrderd) q=j; break; for(d=i;d320;d+) for( j=0;jM;j+) if(j!=q) if(Simulatei-1j=PageOrderd) n=j; break; for(d=

13、i;d320;d+) for( j=0;jM;j+) if(j!=q&j!=n) if(Simulatei-1j=PageOrderd) m=j; break; for(d=i;d320;d+) for( j=0;jM;j+) if(j!=q&j!=n&j!=m) if(Simulatei-1j=PageOrderd) l=j; break; return (10-q-n-m-l); 说明:将请求数后面产生的的随机数一个一个和内存中的物理块的数比较,当相等的时候,记下相等的物理块号,再做第二个循环,第二个循环比较是除了第一个记录下来的数之外的4个数,相等的时候,再记下相等的物理块号,然后再做第

14、三个循环.第四个做完后返回10减去刚刚找到的物理块号之和,这个就是要置换的数的列号。void Init() /初始化页框 for(int k=0;kMaxNum;k+) int n=rand()%320;/随机数产生320次指令 PageOrderk=n/10;/根据指令产生320次页面请求 for(int i=0;iMaxNum;i+)/初始化页面访问过程 for(int j=0;jM;j+) Simulateij=-1; for(int q=0;qM;q+)/初始化最久未使用数组 PageCountq=0; void designBy() printf(n); printf( 课题四:页面

15、置换算法 n); printf( 班 级:11计本2班 n); printf( 学 号:20110303214 n); printf( 姓 名:周玉亭 n); printf(n);void OutPut()/输出 int i,j; cout页面访问序列:endl; for(j=0;jMaxNum;j+) coutPageOrderj ; coutendl; cout页面访问过程:endl; for(i=0;i10;i+) for(j=0;jM;j+) if(Simulateij=-1) cout ; else coutSimulateij ; coutendl; coutendl; cout缺

16、页数= LackNumendl; cout命中率= PageRateendl; cout-endl;说明:将FIFO算法、LRU算法、OPT算法的页面访问过程显示出来,并输出缺页数和命中率。void FIFO()/FIFO算法 int j,x=0,y=0; LackNum=0, Init(); for(j=0;jM;j+)/将前五个页面请求直接放入内存中 for(int k=0;k=j;k+) if(j=k) Simulatejk=PageOrderj; else Simulatejk=Simulatej-1k; LackNum+; for(x=M;xMaxNum;x+) for(int t=

17、0;tM;t+)/先将前一次页面访问过程赋值给新的页面访问过程 Simulatext=Simulatex-1t; if(!IsExit(x)/根据新访问页面是否存在内存中来更新页面访问过程 LackNum+; Simulatexy%M=PageOrderx; y+; PageRate=1-(float)LackNum/(float)MaxNum);/算出命中率 OutPut();说明:用Simulatexy%M算出需要置换页面,比如假如第6个数内存中没有,那置换时第6行第1列数一定是第一个进来的,我y的值这时候是6,然后y除以m取余,就是6除以5取余也就是1,然后将第一个置换出来。void L

18、RU()/LRU算法 int j,x=0,y=0; LackNum=0, Init(); for(j=0;jM;j+)/将前五个页面请求直接放入内存中 for(int k=0;k=j;k+) PageCountk+; if(j=k) Simulatejk=PageOrderj; else Simulatejk=Simulatej-1k; LackNum+; for(x=M;xMaxNum;x+) for(int t=0;tM;t+)/先将前一次页面访问过程赋值给新的页面访问过程 Simulatext=Simulatex-1t; int p=IsExitLRU(x); if(p=-1)/根据反回

19、的p值来更新页面访问过程 int k; k=Compare(); for(int w=0;wM;w+) if(w!=k) PageCountw+; else PageCountk=1; Simulatexk=PageOrderx; LackNum+; else for(int w=0;wM;w+) if(w!=p) PageCountw+; else PageCountp=1; PageRate=1-(float)LackNum/(float)MaxNum);/算出命中率 OutPut();说明:先用一开始的五个页面放入内存中,然后判断下面要运行的页面是否在内存中,在内存中就直接运行,不在的话

20、,int Compare()算出需要置换的页面。PageCount这个数组记录着内存里5个物理块使用情况,找出需要置换的页面的列数,然后赋值给k,再通过Simulatexk=PageOrderx语句置换,每次要置换时LackNum的值就会加1。void OPT()/OPT算法 int j,x=0,y=0; LackNum=0, Init(); for(j=0;jM;j+)/将前五个页面请求直接放入内存中 for(int k=0;k=j;k+) /PageCountk+; if(j=k) Simulatejk=PageOrderj; else Simulatejk=Simulatej-1k; L

21、ackNum+; for(x=M;xMaxNum;x+) for(int t=0;tM;t+)/先将前一次页面访问过程赋值给新的页面访问过程 Simulatext=Simulatex-1t; int p=IsExitOPT(x); if(p=-1)/根据反回的p值来更新页面访问过程 int k; k=Compare2(x); Simulatexk=PageOrderx; LackNum+; PageRate=1-(float)LackNum/(float)MaxNum);/算出命中率 OutPut();说明:先用一开始的五个页面放入内存中,然后判断下面要运行的页面是否在内存中,在内存中就直接运

22、行,不在的话,就将int Compare2()算出需要置换的页面的列数,带入置换,每次要置换时LackNum的值就会加1,最后输出页面的置换的过程,算出缺页率。void YourChoice(int choice) switch(choice) case 1: cout-endl; coutFIFO算法结果如下:endl; FIFO(); break; case 2: cout-endl; coutLRU算法结果如下:endl; LRU(); break; case 3: cout-endl; coutOPT算法结果如下:endl; OPT(); break; case 4: break; d

23、efault: cout重新选择算法:1-FIFO 2-LRU 3-OPT 4-退出 choice; YourChoice(choice); void main() system(color 0E); designBy(); int choice,i=1; while(i) cout请选择算法:1-FIFO 2-LRU 3-OPT 4-退出 choice; if(choice=4) i=0; else YourChoice(choice); 四调试分析调试过程和调试结果一开始运行出来的界面:选择FIFO算法运行的界面:选择FRU算法运行的界面:选择OPT算法运行的界面:五、总结 1、遇到的问题

24、在做最佳置换算法时,对于选出要置换的页面的算法遇到了很大的困难,程序是对的,算法有点问题,可是理论上也是对的。很纠结的一个问题啊! 2、不足最佳置换算法在最后实现的时候还是有点问题的。我就不告诉老师了,让它成为一个秘密吧! 3、心得体会一周半的课程设计,在忙忙碌碌的日子中悄悄地结束了。虽然课程设计的时间比较短,但是带给我的影响还是很大的。不仅加强了我敲代码的能力,而且也培养了我对一个算法执着的精神。通过课程设计,让枯燥乏味的课本变得多态有趣,让我觉得学习也不是那么枯燥的一件事,同时,课程设计也让我深入地理解了课本的知识,让我我懂得了理论与实际相结合是很重要的,只有理论知识是远远不够的,只有把所

25、学的理论知识与实践相结合起来,从理论中得出结论,才能真正为社会服务,从而提高自己的实际动手能力和独立思考的能力。知识的获得是无止境的,只要你想学,只要你行动,就一定会有所收获的。回首这两个星期的课程设计,在做最佳置换算法时,对于选出要置换的页面的算法遇到了很大的困难,程序是对的,算法有点问题,可是理论上也是对的。当时课上忍了半天也没忍出来,后来回去到图书馆我请姚方贵同学来和我一起解决,终于把那个错的地方找出来了,在此,我由衷的感谢老师和姚方贵同学对我的帮助,我永远会记得大家一起努力的日子!六、参考文献(1)汤子瀛,哲风屏,汤小冉等,计算机操作系统,西安电子科技大学出社,2001年8月(2)张尧学,史美林,计算机操作系统课程,清华大学出版社,2000年

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1