第7次常用页面置换算法模拟实验文档格式.docx

上传人:b****1 文档编号:14677365 上传时间:2022-10-23 格式:DOCX 页数:25 大小:280.76KB
下载 相关 举报
第7次常用页面置换算法模拟实验文档格式.docx_第1页
第1页 / 共25页
第7次常用页面置换算法模拟实验文档格式.docx_第2页
第2页 / 共25页
第7次常用页面置换算法模拟实验文档格式.docx_第3页
第3页 / 共25页
第7次常用页面置换算法模拟实验文档格式.docx_第4页
第4页 / 共25页
第7次常用页面置换算法模拟实验文档格式.docx_第5页
第5页 / 共25页
点击查看更多>>
下载资源
资源描述

第7次常用页面置换算法模拟实验文档格式.docx

《第7次常用页面置换算法模拟实验文档格式.docx》由会员分享,可在线阅读,更多相关《第7次常用页面置换算法模拟实验文档格式.docx(25页珍藏版)》请在冰豆网上搜索。

第7次常用页面置换算法模拟实验文档格式.docx

2)实验报告中必须包括:

设计思想、数据定义(包括详细说明)、处理流程(详细算法描述与算法流程图)、源代码、运行结果、体会等部分。

3)必须模拟本实验内容中提到得算法中得至少2种页面置换算法。

4)比较不同页面置换算法得效率

实验内容

编写一个程序,使用以下页面置换算法中得某2种分别模拟一个分页系统,并统计同一个页面访问序列情况下不同页面置换算法引发得缺页中断次数。

1、第二次机会算法(SecondChance)

2、最近最少使用算法(LeastRecentlyUsed,LRU)

3、最不常用算法(NotFrequently Used,NFU)

4、最近未使用算法(NotRecentlyUsed,NRU)

5、时钟页面置换算法

6、老化算法(aging)

页框得数量固定为4,虚拟页面数为8。

实验输入为访问页面序列,比如0,1 ,3,2,7,1

实验用到得软件(:

Vs,word,processon

实验内容、关键步骤(流程图、代码等)及结果分析(70分)

一、先进先出页面置换算法

1、基本思想:

地址映射过程中,若在页面中发现所要访问得页面不再内存中,则产生缺页中断.当发生缺页中断时操作系统必须在内存选择一个页面将其移出内存,以便为即将调入得页面让出空间.而用来选择淘汰哪一页得规则叫做页面置换算法。

最简单得页面置换算法就是先入先出(FIFO)法。

2、算法流程图

3、步骤说明

(1)初始化

voidinit(){//初始化

ﻩinti;

ﻩfor(i =0;

i 〈 page_frame_number;

i++){

page_table[i]、page_id=-1;

ﻩpage_table[i]、load_time=-1;

page_table[i]、last_visit_time= -1;

}

(2)选择算法,输入插入页面号。

进入判断函数

int judge(){//判断页框就是否满,或者页框里面就是否已存在页面

inti;

for(i = 0;

i 〈page_frame_number;

 i++){

ﻩif(page_table[i]、page_id==—1 ||page_table[i]、page_id ==page_id)

returni;

return—2;

}

之后根据返回数得不同决定了不同类型

返回—2则说明页框满且页框里面没有存在要插入得页面。

返回-1则说明页框未满

返回其它数则说明页框里存在相同得页面

(3)//当没有空页框,并且页面本身也没有存在,则执行一下代码

ﻩﻩqsort(page_table, page_frame_number,sizeof(structPage_table),cmp);

//按照装入时间从小到大排序

ﻩﻩpage_table[0]、page_id =page_id;

ﻩﻩpage_table[0]、load_time= counter;

ﻩﻩpage_table[0]、last_visit_time=counter;

ﻩﻩﻩpage_interrupt_number++;

将页框号为0得页面置换成最新插入得页面。

intcmp(const void*p,const void*q){//按照装入时间从小到大排序 

ﻩintc =(*(structPage_table*)p)、load_time-(*(structPage_table*)q)、load_time;

if (c> 0)

ﻩﻩreturn1;

else

ﻩreturn—1;

排序函数,将页面按装入时间从小到大排序

(4)//如果页面未满,则将页面替换在空页框里

ﻩﻩif(page_table[j]、page_id== —1){

page_table[j]、page_id =page_id;

ﻩﻩﻩpage_table[j]、load_time=counter;

ﻩﻩpage_table[j]、last_visit_time =counter;

ﻩﻩpage_interrupt_number++;

则将页面替换在页框号最小得空页框里

(5)//如果页面本身存在页框中,则执行一下代码

ﻩﻩpage_table[j]、last_visit_time= counter;

则更新页面得最近访问时间

(6)qsort(page_table, page_frame_number,sizeof(structPage_table),cmp3);

//按照装入时间从小到大排序

ﻩﻩprint

(2);

打印出页表详细信息

printf("页表信息:

\n页 号页框号 装入时间最近访问时间\n”);

ﻩﻩfor(j=0;

 j〈page_frame_number;

j++){

ﻩprintf("%4d%8d%7d%7d\n”,page_table[j]、page_id,j,page_table[j]、load_time, page_table[j]、last_visit_time);

};

break;

排序函数

int cmp3(constvoid*p,constvoid*q){//按照装入时间从小到大排序,,并且不要排序没页面得部分

if((*(structPage_table*)p)、page_id!

=—1&

&(*(structPage_table*)q)、page_id!

=-1){

ﻩﻩintc =(*(struct Page_table*)p)、load_time -(*(structPage_table*)q)、load_time;

ﻩﻩif(c〉0)

ﻩﻩreturn1;

ﻩﻩelse

ﻩreturn—1;

(7)并计算出中断页面次数及命中概率,并打印页表出来

int sum;

ﻩsum =((virtual_page_number—page_interrupt_number)*100/virtual_page_number);

printf("缺页中断次数:

%d\n"

page_interrupt_number);

ﻩprintf("

中断命中率:

%d%%\n”,sum);

ﻩprintf("打印出页面\n”);

for(inti =0;

i〈 page_frame_number;

i++)

ﻩfor(intg=1;

g〈= virtual_page_number;

g++)

ﻩ{

ﻩﻩprintf("

%4d",pr[i][g]);

ﻩ}

ﻩprintf(”\n”);

4、实现

(1)选择FIFO算法

(2)输入页面号,列出页表详细信息

(3)输入—1,结束输入,显示统计结果及页表

二、最近最少使用页面置换算法

1、基本思想:

在前面几条指令中使用频繁得页面很可能在后面得几条指令中频繁使用.反过来说,已经很久没有使用得页面很可能在未来较长得一段时间内不会被用到。

这个,就就是著名得局部性原理——比内存速度还要快得cache,也就是基于同样得原理运行得。

因此,我们只需要在每次调换时,找到最近最久使用得那个页面调出内存。

2、算法流程图

3、步骤说明:

(1)初始化

voidinit(){//初始化

ﻩinti;

for(i =0;

 i<

page_frame_number;

i++){

ﻩpage_table[i]、page_id=-1;

page_table[i]、load_time =-1;

ﻩﻩpage_table[i]、last_visit_time=-1;

ﻩ}

(2)选择算法,输入插入页面号。

intjudge(){//判断页框就是否满,或者页框里面就是否已存在页面

ﻩint i;

ﻩfor(i=0;

 i〈page_frame_number;

 i++){

if (page_table[i]、page_id== -1||page_table[i]、page_id==page_id)

ﻩreturni;

return—2;

返回-2则说明页框满且页框里面没有存在要插入得页面.

(3)//当没有空页框,并且页面本身也没有存在,则执行一下代码

ﻩﻩqsort(page_table,page_frame_number,sizeof(struct Page_table),cmp1);

//按照最后访问时间从小到大排序ﻩ

     page_table[0]、page_id=page_id;

ﻩpage_table[0]、load_time=counter;

ﻩpage_table[0]、last_visit_time= counter;

ﻩpage_interrupt_number++;

intcmp1(const void*p,constvoid*q){//按照最后访问时间从小到大排序

intc =(*(struct Page_table*)p)、last_visit_time- (*(structPage_table*)q)、last_visit_time;

if(c>

0)

ﻩﻩreturn 1;

ﻩelse

ﻩﻩreturn-1;

排序函数,将页面按最后访问时间从小到大排序

(4)//如果页面未满,则将页面替换在空页框里

ﻩif(page_table[j]、page_id==-1){

ﻩpage_table[j]、page_id =page_id;

ﻩﻩﻩpage_table[j]、load_time=counter;

ﻩﻩﻩpage_table[j]、last_visit_time =counter;

ﻩﻩpage_interrupt_number++;

(5)//如果页面本身存在页框中,则执行一下代码

ﻩﻩpage_table[j]、last_visit_time=counter;

(6)qsort(page_table, page_frame_number,sizeof(structPage_table), cmp2);

//按照最后访问时间从小到大排序

ﻩprint

(2);

printf(”页表信息:

\n页号页框号 装入

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

当前位置:首页 > 表格模板 > 表格类模板

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

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