操作系统存储管理实验报告.docx

上传人:b****7 文档编号:16459524 上传时间:2023-07-13 格式:DOCX 页数:12 大小:44.90KB
下载 相关 举报
操作系统存储管理实验报告.docx_第1页
第1页 / 共12页
操作系统存储管理实验报告.docx_第2页
第2页 / 共12页
操作系统存储管理实验报告.docx_第3页
第3页 / 共12页
操作系统存储管理实验报告.docx_第4页
第4页 / 共12页
操作系统存储管理实验报告.docx_第5页
第5页 / 共12页
操作系统存储管理实验报告.docx_第6页
第6页 / 共12页
操作系统存储管理实验报告.docx_第7页
第7页 / 共12页
操作系统存储管理实验报告.docx_第8页
第8页 / 共12页
操作系统存储管理实验报告.docx_第9页
第9页 / 共12页
操作系统存储管理实验报告.docx_第10页
第10页 / 共12页
操作系统存储管理实验报告.docx_第11页
第11页 / 共12页
操作系统存储管理实验报告.docx_第12页
第12页 / 共12页
亲,该文档总共12页,全部预览完了,如果喜欢就下载吧!
下载资源
资源描述

操作系统存储管理实验报告.docx

《操作系统存储管理实验报告.docx》由会员分享,可在线阅读,更多相关《操作系统存储管理实验报告.docx(12页珍藏版)》请在冰点文库上搜索。

操作系统存储管理实验报告.docx

操作系统存储管理实验报告

实验五存储管理

一、实验目的

1、加深对操作系统存储管理的理解

2、能过模似页面调试算法,加深理解操作系统对存的高度管理

2、总的设计思想、环境语言、工具等总的设计思想:

1、编写函数计算并输出下述各种算法的命中率

1OPT页面置换算法

OPT所选择被淘汰的页面是已调入存,且在以后永不使用的,或是在最长时间不再被访问的页面。

因此如找出这样的页面是该算法的关键。

可为每个页面设置一个步长变量,其初值为一足够大的数,对于不在存的页面,将其值重置为零,对于位于存的页面,其值重置为当前访问页面与之后首次出现该页面时两者之间的距离,因此该值越大表示该页是在最长时间不再被访问的页面,可以选择其作为换出页面。

2FIFO页面置换算法

FIFO总是选择最先进入存的页面予以淘汰,因此可设置一个先进先出的忙页帧队列,新调入存的页面挂在该队列的尾部,而当无空闲页帧时,可从该队列首部取下一个页帧作为空闲页帧,进而调入所需页面。

3LRU页面置换算法

LRU是根据页面调入存后的使用情况进行决策的,它利用“最近的过去”作为“最近的将来”的近似,选择最近最久未使用的页面予以淘汰。

该算法主要借助于页面结构中的访问时间time来实现,time记录了一个页面上次的访问时间,因此,当须淘汰一个页面时,选择处于存的页面中其time值最小的页面,即最近最久未使用的页面予以淘汰。

4LFU页面置换算法

LFU要求为每个页面配置一个计数器(即页面结构中的counter),一旦某页被访问,则将其计数器的值加1,在需要选择一页置换时,则将选择其计数器值最小的页面,即存中访问次数最少的页面进行淘汰。

5NUR页面置换算法

NUR要求为每个页面设置一位访问位(该访问位仍可使用页面结构中的counter表示),当某页被访问时,其访问位counter置为1。

需要进行页面置换时,置换算法从替换指针开始(初始时指向第一个页面)顺序检查处于存中的各个页面,如果其访问位为0,就选择该页换出,否则替换指针下移继续向下查找。

如果存中的所有页面扫描完毕未找到访问位为0的页面,则将替换指针重新指向第一个页面,同时将存中所有页面的访问位置0,当开始下一轮扫描时,便一定能找到counter为0的页面。

2、在主函数中生成要求的指令序列,并将其转换成页地址流;在不同的存容量下调用上述函数使其计算并输出相应的命中率。

环境语言:

Linux下的GNU编译环境

三、数据结构与模块说明

程序中用到的数据结构、类型定义及主要的函数原型如下:

1、数据结构

(1)页面结构

typedefstruct{

intpn,pfn,counter,time;

}pl_type;

pl_typepl[total_vp];

其中pn为页面号(页号),pfn为页帧号(物理块号),counter为一个期访问该页面的次数,time为访问时间;pl[total_vp]为页面结构数组,由于共有320条指令,每页可装入10条指令,因此虚页长total_vp的值为32。

(2)页帧控制结构

structpfc_struct{

intpn,pfn;

structpfc_struct*next;

};

typedefstructpfc_structpfc_type;

pfc_typepfc[total_vp],*freepf_head,*busypf_head,*busypf_tail;

其中pfc[total_vp]定义用户进程的页帧控制结构数组,在该实验中,用户存工作区是动态变化的,最多可达到用户进程的虚页数目,即32个物理块。

*freepf_head为空闲页帧头的指针

*busypf_head为忙页帧头的指针

*busypf_tail忙页帧尾的指针

2、变量定义

(1)inta[total_instruction]:

指令流数组

(2)intdiseffect:

页面失效次数

(3)intpage[total_instruction]:

每条指令所属页面号

(4)intoffset[total_instruction]:

每页装入10条指令后取模运算得出的页偏移地址

(5)inttotal_pf:

用户进程的存页帧数

3、主要函数

(1)voidinitialize(int):

初始化函数

该函数主要对页面结构数组pl和页帧结构数组pfc进行初始化,如置页面结构中的页面号pn,初始化页帧号pfn为空,访问次数counter为0,访问时间time为-1;同样对页帧数组进行初始化,形成一个空闲页帧队列。

(2)voidOPT(int):

计算使用最佳页面算法时的命中率

(3)voidFIFO(int):

计算使用先进先出页面置换算法时的命中率

(4)voidLRU(int):

计算使用最近最久未使用页面置换算法时的命中率

(5)voidLFU(int):

计算使用最少使用置换算法时的命中率

(6)voidNUR(int):

计算使用最近未使用置换算法时的命中率

四、主要算法的设计与实现

voidFIFO(inttotal_pf)/*先进先出页面置换算法*/

{

inti,j;

pfc_type*p;

initialize(total_pf);

busypf_head=busypf_tail=NULL;

for(i=0;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_head->pfn;

if(busypf_tail==NULL)/*若忙页帧队列为空,则将其头尾指针都指向刚调入页面所在的页帧*/

busypf_head=busypf_tail=freepf_head;

else{//否则,将刚调入页面所在的页帧挂在忙页帧队列尾部

busypf_tail->next=freepf_head;

busypf_tail=freepf_head;

}

freepf_head=p;//空闲页帧头指针后移

}

}

printf("FIFO:

%6.4f",1-(float)diseffect/320);

}

voidLRU(inttotal_pf)/*最近最久未使用页面置换算法*/

{

inti,j;

intmin,minj,present_time;

initialize(total_pf);

present_time=0;

for(i=0;i

{

if(pl[page[i]].pfn==INVALID)/*页面失效*/

{

diseffect++;

if(freepf_head==NULL)/*无空闲页帧*/

{

min=32767;

for(j=0;j

if(min>pl[j].time&&pl[j].pfn!

=INVALID)

{

min=pl[j].time;

minj=j;

}

}

freepf_head=&pfc[pl[minj].pfn];//腾出一个单元

pl[minj].pfn=INVALID;

pl[minj].time=-1;

freepf_head->next=NULL;

}

pl[page[i]].pfn=freepf_head->pfn;//有空闲页面,改为有效

pl[page[i]].time=present_time;//修改页面的访问时间

freepf_head=freepf_head->next;//减少一个free页面

}

else

pl[page[i]].time=present_time;//命中则修改该单元的访问时间

present_time++;

}

printf("LRU:

%6.4f",1-(float)diseffect/320);

}

voidNUR(inttotal_pf)/*最近未使用页面置换算法*/

{

inti,j,dp,cont_flag,old_dp;

initialize(total_pf);

dp=0;

for(i=0;i

{

if(pl[page[i]].pfn==INVALID)/*页面失效*/

{

diseffect++;

if(freepf_head==NULL)/*无空闲页帧*/

{

cont_flag=TRUE;

old_dp=dp;

while(cont_flag)

{

if(pl[dp].counter==0&&pl[dp].pfn!

=INVALID)

cont_flag=FALSE;//找到位于存且未被访问的页面

else

{

dp++;

if(dp==total_vp)dp=0;//将替换指针重新指向第一个页面

if(dp==old_dp)

{/*若存中所有页面扫描完毕未找到访问位为0的页面,将存中所有页面的访问位置0*/

for(j=0;j

pl[j].counter=0;

}

}

}

freepf_head=&pfc[pl[dp].pfn];//腾出一个单元

pl[dp].pfn=INVALID;

freepf_head->next=NULL;

}

pl[page[i]].pfn=freepf_head->pfn;//有空闲页面,改为有效

freepf_head=freepf_head->next;//减少一个free页面

}

else

pl[page[i]].counter=1;//命中则将访问位置1

if(i%clear_period==0)//清零期到,将所有访问位清零

{

for(j=0;j

pl[j].counter=0;

}

}

printf("NUR:

%6.4f",1-(float)diseffect/320);

}

voidOPT(inttotal_pf)/*最佳页面置换算法*/

{

inti,j,max,maxpage,d,dist[total_vp];

initialize(total_pf);

for(i=0;i

{

if(pl[page[i]].pfn==INVALID)/*页面失效*/

{

diseffect++;

if(freepf_head==NULL)/*无空闲页面*/

{

for(j=0;j

{

if(pl[j].pfn!

=INVALID)//所有位于存页面的距离变量赋一足够大的数

dist[j]=32767;

else//不在存的页面该变量则置为0

dist[j]=0;

}

d=1;

/*对于位于存且在当前访问页面之后将再次被访问的页面,dist重置为当前页面与之后首次出现该页面时两者之间的距离*/

for(j=i+1;j

{

if(pl[page[j]].pfn!

=INVALID&&dist[page[j]]==32767)

dist[page[j]]=d;

d++;

}

max=-1;

//查找dist变量值最大的页面作为换出页面

for(j=0;j

{

if(max

max=dist[j];

maxpage=j;

}

}

freepf_head=&pfc[pl[maxpage].pfn];//腾出一个单元

freepf_head->next=NULL;

pl[maxpage].pfn=INVALID;

}

pl[page[i]].pfn=freepf_head->pfn;//有空闲页面,改为有效

freepf_head=freepf_head->next;//减少一个free页面

}

}

printf("OPT:

%6.4f",1-(float)diseffect/320);

}

voidLFU(inttotal_pf)/*最少使用页面置换算法*/

{

inti,j,min,minpage;

initialize(total_pf);

for(i=0;i

{

if(pl[page[i]].pfn==INVALID)//页面失效

{

diseffect++;

if(freepf_head==NULL)//无空闲页帧

{

min=32767;

for(j=0;j

{//查找位于存且访问次数最少的页面作为换出页面

if(min>pl[j].counter&&pl[j].pfn!

=INVALID)

{

min=pl[j].counter;

minpage=j;

}

pl[j].counter=0;

}

freepf_head=&pfc[pl[minpage].pfn];//腾出一个单元

pl[minpage].pfn=INVALID;

freepf_head->next=NULL;

}

pl[page[i]].pfn=freepf_head->pfn;//有空闲页面,改为有效

pl[page[i]].counter++;//增加页面访问次数

freepf_head=freepf_head->next;//减少一个free页面

}

else

pl[page[i]].counter++;//命中增加页面访问次数

}

printf("LFU:

%6.4f",1-(float)diseffect/320);

}

五、运行结果

本实验的运行结果如下图所示(以OPT、FIFO、LRU为例):

从上述结果可知,随着存页面数的增加,三种算法的访问命中率逐渐增大。

在存页面数为4~25个页面之间时,三种算法的命中率大致在56%至88%之间变化,但是,OPT算法和其他两种算法之间的差别一般在6~12个百分点左右。

在存页面为25~32个页面时,由于用户进程的所有指令基本上都已装入存,从而命中率增加较大,各种算法之间的差别不大。

比较上述三种算法,OPT算法的命中率最高,LRU算法和FIFO算法的命中率则较为接近。

6、总结

经过测试结果完全正常。

经过编写和学习让我对操作系统面的知识更深一步的得到了理解和巩固。

让我在今后的学习中可以更好的去理解和体会。

展开阅读全文
相关资源
猜你喜欢
相关搜索
资源标签

当前位置:首页 > 解决方案 > 学习计划

copyright@ 2008-2023 冰点文库 网站版权所有

经营许可证编号:鄂ICP备19020893号-2