- 1、本文档共9页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
实验五 存储管理
一、实验目的
1 、加深对操作系统存储管理的理解
2 、能过模似页面调试算法,加深理解操作系统对内存的高度管理
总的设计思想、环境语言、工具等总的设计思想:
1、编写函数计算并输出下述各种算法的命中率
OPT页面置换算法
OPT所选择被淘汰的页面是已调入内存,且在以后永不使用的,或是在最长时间内不再被访问的页面。因此如何找出这样的页面是该算法的关键。可为每个页面设置一个步长变量,其初值为一足够大的数,对于不在内存的页面,将其值重置为零,对于位于内存的页面,其值重置为当前访问页面与之后首次出现该页面时两者之间的距离,因此该值越大表示该页是在最长时间内不再被访问的页面,可以选择其作为换出页面。
FIFO页面置换算法
FIFO总是选择最先进入内存的页面予以淘汰,因此可设置一个先进先出的忙页帧队列,新调入内存的页面挂在该队列的尾部,而当无空闲页帧时,可从该队列首部取下一个页帧作为空闲页帧,进而调入所需页面。
LRU页面置换算法
LRU是根据页面调入内存后的使用情况进行决策的,它利用“最近的过去”作为“最近的将来”的近似,选择最近最久未使用的页面予以淘汰。该算法主要借助于页面结构中的访问时间time来实现,time记录了一个页面上次的访问时间,因此,当须淘汰一个页面时,选择处于内存的页面中其time值最小的页面,即最近最久未使用的页面予以淘汰。
LFU页面置换算法LFU要求为每个页面配置一个计数器(即页面结构中的counter),一旦某页被访问,则将其计数器的值加1,在需要选择一页置换时,则将选择其计数器值最小的页面,即内存中访问次数最少的页面进行淘汰。
NUR页面置换算法页面结构typedef struct{
int pn, pfn, counter, time;
} pl_type ;
pl_type pl[total_vp];
其中pn为页面号,pfn为页帧号,time为访问时间页帧控制结构
struct pfc_struct{ int pn, pfn;
struct pfc_struct *next;
};
typedef struct pfc_struct pfc_type;
pfc_type pfc[total_vp], *freepf_head, *busypf_head, *busypf_tail;
其中pfc[total_vp]定义用户进程页控制结构
*freepf_head为空闲页帧头的指针
*busypf_head为忙页帧头的指针
*busypf_tail忙页帧尾的指针变量定义
int a[total_instruction]: 指令流数组
int diseffect: 页面失效次数
int page[total_instruction]: 每条指令所属页面号
int offset[total_instruction]: 每页装入10条指令后取模运算得出的页内偏移地址
int total_pf: 用户进程的内存数函数
void initialize(int): 初始化函数
(2) void OPT(int): 计算使用算法时的命中率void FIFO(int): 计算使用算法时的命中率void LRU(int): 计算使用算法时的命中率计算使用最少使用置换算法时的命中率
计算使用最近未使用置换算法时的命中率void FIFO(int total_pf) /*先进先出页面置换算法*/
{
int i,j;
pfc_type *p;
initialize(total_pf);
busypf_head=busypf_tail=NULL;
for(i=0;itotal_instruction;i++)
{
if(pl[page[i]].pfn==INVALID) /*页面失效*/
{
diseffect=diseffect+1;
if(freepf_head==NULL) /*无空闲页帧*/
{
p=busypf_head-next;
pl[busypf_head-pn].pfn=INVALID; //将忙页帧队首页面作为换出页面
freepf_head=busypf_head;
freepf_head-next=NULL;
busypf_head=p; //忙页帧头指针 }
p=freepf_head-next; //有空闲页帧
freepf_head-next=NULL;
freepf_head-pn=page[i]; /* 将所需页面调入空闲页帧 */
pl[page[i]].pfn=freepf_
您可能关注的文档
- 什么是富人思维?(深度好文)讲述.doc
- 体验亲情感恩父母二年级讲述.ppt
- 什么是管理?能源管理体系运行讲述.pptx
- 体育行业研究——击剑领域讲述.pptx
- 初二上学期期中家长会课件讲解.ppt
- 安全管理体系及保证措施已打印讲解.doc
- 初二学业纸五六章讲解.doc
- 体验式商业案例分享讲述.pptx
- 初级电算化第三章讲解.doc
- 体育课出勤考勤表讲述.doc
- 2024年河南省濮阳县《执业药师之中药学专业二》考试必刷200题及答案下载.docx
- 2024年河南省濮阳县《一级注册建筑师之建筑物理与建筑设备》资格考试通关秘籍题库附答案【能力提升】.docx
- 2024年河南省濮阳县《一级注册建筑师之建筑物理与建筑设备》资格考试完整题库附参考答案(研优卷).docx
- 活力闪耀,砥砺青春.pptx
- 2024年河南省濮阳县《一级注册建筑师之建筑物理与建筑设备》考试必刷100题题库(易错题).docx
- 2024年河南省濮阳县《一级注册建筑师之建筑物理与建筑设备》资格考试必刷100题题库附答案(实用).docx
- 2024年河南省濮阳县《一级注册建筑师之建筑物理与建筑设备》考试必背100题完整题库及参考答案(名师.docx
- BIM施工策划表格编辑01课件讲解.pptx
- 2024年河南省潢川县《一级注册建筑师之建筑物理与建筑设备》资格考试必背100题真题题库【培优A卷】.docx
- 2024年河南省潢川县《执业药师之西药学专业一》资格考试必刷200题大全(研优卷).docx
文档评论(0)