好文档 - 专业文书写作范文服务资料分享网站

页面置换算法模拟

天下 分享 时间: 加入收藏 我要投稿 点赞

页面置换算法模拟

报 告(全文结束》》 /全文结束》》学年

第1学期)课程名称操作系统原理实验名称实验6:页面置换算法模拟实验时间xx年12月10日指导单位软件工程系指导教师 杨 健学生姓名班级学号学院(系)软件工程系专 业计算机软件与服务外包实验名称实验1:Linux操作、使用、编程与进程创建指导教师杨健实验类型实验实验学时2实验时间xx、

12、10 一、 实验目的

1、通过模拟实现几种基本页面置换的算法,了解虚拟存储技术的特点。

2、掌握虚拟存储请求页式存储管理中几种基本页面置换算法的基本思想,并至少用三种算法来模拟实现。

3、通过对几种置换算法页面的比较,来对比他们的优缺点,并通过比较更换频率来对比它们的效率。

二、实验环境(实验设备)Windows2000 Visual Studio 三、实验内容设计一个虚拟存储区和内存工作区,并使用下述算法来模拟实现页面的置换:

1、先进先出的算法(FIFO) 2、 最近最久未使用算法(LRU)

第 1 页 共 1 页

3、 最佳置换算法(OPT)实验分析在进程运行过程中,若其所访问的页面不存在内存而需要把它们调入内存,但内存已无空闲时,为了保证该进程能够正常运行,系统必须从内存中调出一页程序或数据送磁盘的对换区中。但应调出哪个页面,需根据一定的算法来确定,算法的好坏,直接影响到系统的性能。一个好的页面置换算法,应该有较低的页面更换频率。

假设分给一作业的物理块数为3 ,页面数为20个。页面号为(20个):7,0,1,2,0,3,0,4,2,3,0,3,2,1,2,0,1,7,0,

11、先进先出(FIFO)置换算法的思路该算法总是淘汰最先进入内存的页面,即选择在内存中驻留时间最久的页面予以淘汰。该算法实现简单,只需把一个进程已调入内存的页面,按照先后次序连接成一个队列,并设置一个替换指针,使它总指向最老的页面。

2、最近久未使用(LRU)置换算法的思路最近久未使用置换算法的替换规则,是根据页面调入内存后的使用情况来进行决策的。该算法赋予每个页面一个访问字段,用来记录一个页面自上次被访问以来所经历的时间,当需淘汰一个页面的时候选择现有页面中其时间值最大的进行淘汰。

3、最佳(OPT)置换算法的思路其所选择的被淘汰的页面,奖是以后不使用的,或者是在未来时间内不再被访问的页面,采用最佳算法,通常可保证获得最低的缺页率。

第 1 页 共 1 页

4、FIFO页面置换算法当需要访问一个新的页面时,首先调用findExist(i)函数来查看物理块中是否就有这个页面,若要查看的页面物理块中就有,则调用display函数直接显示,不需要替换页面;如果要查看的页面物理块中没有,就需要寻找空闲物理块放入,若存在有空闲物理块,则将页面放入;若没有空闲物理块,则调用findReplace函数替换页面。并将物理块中所有页面timer++。

5、LRU页面置换算法

当需要访问一个新的页面,首先调用findExist(i)函数查看物理块中是否就有这个页面。

6、 OPT页面置换算法 当需要访问一个新的页面,首先调用findExist(i)函数来查看物理块中是否有这个页面。

7、寻找置换页面函数findReplace比较三个物理块中的时间标记timer,找到时间最久的。代码#include#include#include#define BLOCK_MAX_SIZE20//最?大洙?物?理え?块é大洙?

小?enum{FIFO=1,LRU,OPT};struct node_page{int address;//指?令?地?址·int page_num;//页?面?号?int next_order;//下?一?次?访?问ê的?次?序ò}*page;//物?理え?块é定¨义?typedef struct BlockNode{int page_index;//page数簓组哩?的?下?标括?struct BlockNode * next;}BlockNode;struct{int

length;//当獭?前°物?理え?块é长¤度èint miss_flag;//缺

第 1 页 共 1 页

ā?页?标括?志?,?若?为a1,?则ò缺ā?页?int miss_count;//缺ā?页?次?数簓 BlockNode*front;

BlockNode*rear;}Block;//本?程ì序ò中D全?局?变?量?名?均ù由

?两?个?单蹋?词洙?组哩?成é,?且ò开a头

?字?母?

大洙?写′int BlockSize =5;//物?理え?块é大洙?小?int PageCount =200;//页?面?总哩?数簓int PageSize =1024;//页?面?大洙?小?int AddrRange =8*1024;//访?问ê地?址·范?围§int get_num(int down,int up)//得?到?一?个?down~up之?间?的?整?数簓{int num;char

str[111];while(1){fgets(str,111*sizeof(int),stdin);num=atoi(str);//把?字?符?串?中D的?数簓字?转羇换?为a整?数簓if(num>=down&& num<=up)

break;printf(\输?入?范?围§有瓺误ó,请?重?新?输?入?:\构1造ì一?个?空?的?物?理え?块é队ó列

{Block、rear=Block、

front=(BlockNode*)malloc(sizeof(BlockNode));if(!Block、front){printf(\内ú存?分?配?失骸?败悒?\\n\

exit(0);}Block、length=0;Block、miss_count=0;Block、rear->next=NULL;}void enqueue(int page_index)//入?队

ó{BlockNode*node=(BlockNode*)malloc(sizeof(BlockNode));if(!node){printf(\内ú存?分?配?失骸?败

悒?\\n\

第 1 页 共 1 页

>next=NULL;Block、length++;Block、rear->next=node;Block、rear=node;}void dequeue()//出?队

ó{BlockNode*node;node=Block、front->next;Block、front->next=node->next;if(node== Block、rear)Block、rear=Block、front;free(node);Block、length--;}void clear_block()//清?空?物?理え?块é{while(Block、

rear=Block、front->next){Block、front->next=Block、rear->next; free(Block、rear);Block、length--;}Block、rear=Block、front;Block、length=0;Block、

miss_count=0;}void destroy_block()//销ú毁ù物?理え?块é{while(Block、rear=Block、front){Block、front=Block、front->next;free(Block、rear);}free(page);}void init_page()//初?始?化ˉ页?面?系μ列

{int

i,j;srand(time(NULL));//用?当獭?前°系μ统?时骸?间?来ぁ?初?始?化ˉ随?机ú种?子哩?page=(struct node_page*)

malloc(PageCount*sizeof(struct

node_page));for(i=0;i

page_num){page[i]、next_order=j;break;}//if}//forif(j== PageCount)//说μ明÷page[i]以?后ó都?不?会á再ù访?问

第 1 页 共 1 页

页面置换算法模拟

页面置换算法模拟报告(全文结束》》/全文结束》》学年第1学期)课程名称操作系统原理实验名称实验6:页面置换算法模拟实验时间xx年12月10日指导单位软件工程系指导教师杨健学生姓名班级学号学院(系)软件工程系专业计算机软件与服务外包实验名称实验1:Linux操作、使用、编程与进程创建指导教师杨健实验类型实验实验学时2实验
推荐度:
点击下载文档文档为doc格式
9jh4824ddr7s7tu43p391qw0b8cv4600t1n
领取福利

微信扫码领取福利

微信扫码分享