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

加入VIP,免费下载
 

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

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

下载须知

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

版权提示 | 免责声明

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

操作系统请求页式存储管理实验报告Word格式.docx

1、2. 实验内容 (1) 通过随机数产生一个指令序列,共320条指令 指令的地址按下述原则生成:a) 50% 的指令是顺序执行的;b) 25% 的指令是均匀分布在前地址部分;c) 25% 的指令是均匀分布在后地址部分;具体的实施方法是:a) 在0,319的指令地址之间随机选取一起点m;b) 顺序执行一条指令,即执行地址为m+1的指令;c) 在前地址0,m+1中随机选取一条指令并执行,该指令的地址为m,;d) 顺序执行一条指令,其地址为m,+1;e) 在后地址m,+2,319中随机选取一条指令并执行;f) 重复上述步骤a)f),直到执行320次指令。(2) 将指令序列变换成为页地址流 设:a) 页

2、面大小为1K;b) 用户内存容量为4页到32页;c) 用户虚存容量为32K。在用户虚存中,按每K存放10条指令排列虚存地址,即320条指令在虚存中的存放方式为:第0条第9条指令为第0页(对应虚存地址为0,9);第10条第19条指令为第1页(对应虚存地址为10,19); 第310条第319条指令为第31页(对应虚存地址为310,319)。 按以上方式,用户指令可以组成32页。(3) 计算并输出下述各种算法在不同内存容量下的命中率 a) 先进先出的算法(FIFO);b) 最近最少使用算法(LRU);c) 最佳淘汰算法(OPT);2 命中率=1-页面失效次数/页地址流长度 在本实验中,页地址流长度为

3、320,页面失效次数为每次访问相应指令时,该指令所对应的页不在内存的次数。3. 随机数产生办法 关于随机数产生办法,可以采用操作系统提供的函数,如Linux或UNIX系统提供函数srand()和rand(),分别进行初始化和产生随机数。例如:srand();语句可以初始化一个随机数;a0=10*rand()/32767*319+1;a1=10*rand()/32767*a0;语句可以用来产生a0与a1中的随机数。环境说明 此实验采用的是Win7下Code:blocks 10.05编译器编程。 此word实验文档中采用notepad+的语法高亮。4. 程序设计说明 4.1. 全局变量 const

4、 int maxn = 320; /序列个数 const int max = maxn +20;/数组大小 const int maxp = max/10; /最大页数 int instmax;/指令序列 int pagemax;/页地址流 int size; /内存能容纳的页数 bool inmaxp; /该页是否在内存里,提高效率 int pinmaxp; /现在在内存里的页 其中in数组是为了方便直接判断该页是否在内存里,而不用遍历内存里所有页来判断。fault_n用来记录缺页次数。3 4.2. 随机指令序列的产生 按照实验要求的写了,但是由于没有考虑细节,开始时出了点问题。(1) 当m

5、=319时,我们顺序执行m+1会产生第32页的页地址,从而使页地址没能按要求限制在0, 31之间。解决方法:采用循环模加来避免超出范围。(2) 但是这样之后有可能出现模0的问题。所以我索性将等于0的模数都赋值为160. 最后的程序如下。void produce_inst() int m, n;int num = 0;while(num maxn) m = rand() % maxn;instnum+ = (m+1)%maxn;if(num = maxn) break;m = (m+2) % maxn;if(m = 0) m = 160;n = rand() % m;instnum+ = (n+

6、1)%maxn;n = (n+2) % maxn;m = maxn - n;m = rand() % m + n;instnum+ = m; 4.3. FIFO算法 定义变量ptr。一开始先预调页填满内存。在这一部分,ptr指向下一个要存放的位置。之后继续执行剩下的指令。此时,ptr表示队列最前面的位置,即最先进来的位置,也就是下一个要被替换的位置。ptr用循环加,即模拟循环队列。4.4. LRU算法 定义数组ltu,即last_time_use来记录该页最近被使用的时间。定义变量ti模拟时间的变化,每执行一次加一。4 这个算法,我没有预调页,而是直接执行所有指令。若当前需要的页没在内存里,就

7、寻找最近最少使用的页,也就是ltu最小的页,即最近一次使用时间离现在最久的页,然后替换掉它。或者在内存还未满时,直接写入,这个我以初始化内存里所有页为-1来实现。若已经在内存里了,则只遍历内存内的页,把当前页的最近使用时间改一下即可。 4.5. OPT算法 定义数组ntu, 即next_time_use来记录下一次被使用的时间,即将来最快使用时间。初始化为-1. 开始时预调页填满内存里的页。同样利用变量ptr来表示下一个要存放的位置从而控制预调页的过程。接着初始化ntu数组为-1。然后求出每一页下一次被使用的指令号,以此代替使用时间。如果所有剩下的序列都没有用该页时,则还是-1.这种值为-1的

8、页显然是最佳替换对象。然后执行所有剩下的指令。当该页不在内存里时,遍历ntu数组,遇到-1的直接使用该页,没有则用ntu值最大的,也就是最晚使用的。无论该页在不在内存里,因为这一次已经被使用了,所以都应该更新这个页的ntu,只需往前看要执行的页流,记录下第一个遇到的该页即可。如果没有找到同样添-1即可。#include stdlib.htime.hstring.husing namespace std; /该页是否在内存里,提高效率 int pinmaxp;void welcome() printf(*n);* By schnee On2011-12-06 *n* 班级:09211311 班内

9、序号:30 *n*nn5 void input_hint() n1-create new instruction sequence 2-set memory page number(4 to 32)n3-solve by FIFO algorithm 4-solve by LRU algorithmn5-solve by OPT algorithm 0-exitn*Please input Your choice: /*通过随机数产生一个指令序列,共320条指令*/ void produce_inst() /*将指令序列变换成为页地址流*/ void turn_page_address() f

10、or(int i=0; imaxn; i+) pagei = insti/10; void FIFO_solve() memset(in, false, sizeof(in);int fault_n = 0;/缺页率 int ptr, i;6 /预调页填满空间 ptr = 0; /下一个要放的位置 for(i=0;maxn & ptrsize;if(!inpagei) pinptr+ = pagei;inpagei = true;fault_n+;/继续执行剩下的指令 /队列里最先进来的位置,即下一个要被替换的位置 for(;inpinptr = false;pinptr = pagei;pt

11、r = (ptr+1) % size;nBy FIFO algorithm, the fault-page number is: %dn, fault_n); the hit ratio is : %.2lfn, (1-(fault_n+0.0)/320.0);void LRU_solve() int ltumaxp; /last_time_use int ti = 1; /模拟时间 memset(ltu, 0, sizeof(ltu);memset(pin, -1, sizeof(pin);int min, ptr, i, j;/寻找lru min=1000000; ptr=0;for(j=

12、0; j j+) if(ltuj min) 7 min = ltuj;ptr = j;/替换或写入 if(pinptr != -1) ltuptr = ti+;else/已经在内存里则只需更改最近使用时间 if(pinj = pagei) ltuj = ti+;break;nBy LRU algorithm, the fault-page number is:void OPT_solve() int ntumaxp;/next_time_use int i, j;memset(ntu, -1, sizeof(ntu);/预调页填满 int ptr = 0; fault_n max) max =

13、 ntupinj;ntupagei = -1;for(j=i+1;if(pagej = pagei) ntupagei = j;9 nBy OPT algorithm, the fault-page number is:int main() srand(time(NULL);welcome();int choice;while(1) input_hint();scanf(%d, &choice);nif(choice = 0) BYE-BYE!if(choice = 1) produce_inst();turn_page_address();New page address sequence

14、is set OK!else if(choice = 2) Please input the size of memory page number:size);else if(choice = 3) FIFO_solve();else if(choice = 4) LRU_solve();else if(choice = 5) OPT_solve();else INPUT ERROR ! nreturn 0;10 6. 运行结果及分析 ) 内存 4 5 10 15 20 25 32 285 272 230 178 135 90 32 FIFO 285 274 224 185 139 91 32 LRU 221 202 140 96 68 48 32 OPT 272 262 206 167 128 82 32 FIFO 271 265 204 163 130 86 32 LRU 201 183 127 92 66 47 32 OPT 随着页数的增多,除了FIFO对某些序列会有Beladys anomaly(详见6.2)外,大部分情况和LRU算法、OPT算法都是缺页率减小。OPT是理想情况,效率是最高的。当然当不缺页时,所有的算法缺页次数都是把所有页调进去的次数。LRU算法有时候和FIFO算法的效率差

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

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