没有合适的资源?快使用搜索试试~ 我知道了~
存储管理实验报告.docx
1.该资源内容由用户上传,如若侵权请联系客服进行举报
2.虚拟产品一经售出概不退款(资源遇到问题,请及时私信上传者)
2.虚拟产品一经售出概不退款(资源遇到问题,请及时私信上传者)
版权申诉
0 下载量 24 浏览量
2023-03-22
20:06:51
上传
评论
收藏 319KB DOCX 举报
温馨提示
试读
18页
。
资源推荐
资源详情
资源评论
..
综合性实验报告
专业:网络工程 年级:12 级 班级: 网络工程
期
2014—2015 学年第一学
课程名称
实验地点
项目名称
指导教师
12.3-12.10-12.17-12.24
12.4-12.11-12.18-12.25
实验时间
实验类型
存储管理
综合性
一、实验目的
通过请求页式存储管理中页面置换算法模拟设计,了解虚拟存储技术的特
点,掌握请求页式管理的页面置换算法。
页面置换算法是虚拟存储管理实现的关键,通过本次实验理解内存页面调度
的机制,在模拟实现 FIFO、LRU、OPT、LFU、NUR 几种经典页面置换算法的基
础上,比较各种置换算法的效率及优缺点,从而了解虚拟存储实现的过程。
二、总体设计
1、编写函数计算并输出下述各种算法的命中率
① OPT 页面置换算法
OPT 所选择被淘汰的页面是已调入内存,且在以后永不使用的,或
是在最长时间内不再被访问的页面。因此如何找出这样的页面是该算法
的关键。可为每个页面设置一个步长变量,其初值为一足够大的数,对
于不在内存的页面,将其值重置为零,对于位于内存的页面,其值重置
为当前访问页面与之后首次出现该页面时两者之间的距离,因此该值越
大表示该页是在最长时间内不再被访问的页面,可以选择其作为换出页
面。
专业资料
..
② FIFO 页面置换算法
FIFO 总是选择最先进入内存的页面予以淘汰,因此可设置一个先进
先出的忙页帧队列,新调入内存的页面挂在该队列的尾部,而当无空闲
页帧时,可从该队列首部取下一个页帧作为空闲页帧,进而调入所需页
面。
③ LRU 页面置换算法
LRU 是根据页面调入内存后的使用情况进行决策的,它利用“最近
的过去”作为“最近的将来”的近似,选择最近最久未使用的页面予以
淘汰。该算法主要借助于页面结构中的访问时间 time 来实现,time 记
录了一个页面上次的访问时间,因此,当须淘汰一个页面时,选择处于
内存的页面中其 time 值最小的页面,即最近最久未使用的页面予以淘
汰。
④ LFU 页面置换算法
LFU 要求为每个页面配置一个计数器(即页面结构中的 counter),
一旦某页被访问,则将其计数器的值加 1,在需要选择一页置换时,则
将选择其计数器值最小的页面,即内存中访问次数最少的页面进行淘
汰。
⑤ NUR 页面置换算法
NUR 要求为每个页面设置一位访问位(该访问位仍可使用页面结构
中的 counter 表示),当某页被访问时,其访问位 counter 置为 1。需
要进行页面置换时,置换算法从替换指针开始(初始时指向第一个页面)
顺序检查处于内存中的各个页面,如果其访问位为 0,就选择该页换出,
专业资料
..
否则替换指针下移继续向下查找。如果内存中的所有页面扫描完毕未找
到访问位为 0 的页面,则将替换指针重新指向第一个页面,同时将内存
中所有页面的访问位置 0,当开始下一轮扫描时,便一定能找到 counter
为 0 的页面。
2、
在主函数中生成要求的指令序列,并将其转换成页地址流;在不同
的内存容量下调用上述函数使其计算并输出相应的命中率。
三、实验步骤(包括主要步骤、代码分析等)
主要步骤:
、通过随机数产生一个指令序列,共 320 条指令。其地址按下述原则生成:
①50%的指令是顺序执行的;
②25%的指令是均匀分布在前地址部分;
③25%的指令是均匀分布在后地址部分;
具体的实施方法是:
A.在[0,319]的指令地址之间随机选区一起点 M;
B.顺序执行一条指令,即执行地址为 M+1 的指令;
C.在前地址[0,M+1]中随机选取一条指令并执行,该指令的地址为 M’;
D.顺序执行一条指令,其地址为 M’+1;
E.在后地址[M’+2,319]中随机选取一条指令并执行;
F.重复 A—E,直到执行 320 次指令。
2、指令序列变换成页地址流,设:
①页面大小为 1K;
②用户内存容量为 4 页到 32 页;
专业资料
..
③用户虚存容量为 32K。
在用户虚存中,按每页存放 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 最佳置换算法:先淘汰最不常用的页地址;
D. NUR 最近未使用置换算法;
E. LFU 最少使用置换算法。
命中率=1-页面失效次数/页地址流长度
在本实验中,页地址流长度为 320,页面失效次数为每次访问相应指令时,
该指令所对应的页不在内存的次数。
代码分析:
1、主函数 main.cpp 的代码:
#include <iostream>
#include <string>
#include <vector>
专业资料
剩余17页未读,继续阅读
资源评论
若♡
- 粉丝: 6172
- 资源: 1万+
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功