#计算机操作系统实验模拟比较页面置换页算法和缺页率(1)

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

成绩

计算机操作系统实验

模拟比较页面置换页算法及缺页率

学号200510020220

姓名乔峰

班级信息052

实验名称: 模拟比较页面置换页算法及缺页率

实验目的:(1)掌握先进先出页面置换算法;

(2)掌握最近未用页面置换算法;

(3)了解最近最久未使用页面置换算法以及其他页面置换算法;

(4)熟悉C/C++编程。

实验学时:6学时

实验内容:编写程序,设置不同的页面数,使用不同的页面替换策略算法进行模拟页面替换。先进先出,最近未用页面置换算法等,并计算缺页

率。

实验环境:

(1).PC微机

(2).Windows 操作系统

(3).C/C++开发环境

实验原理及算法参考程序段:

#include

#include

#include

#include

#include

int add[256]/*地址*/,page[256]/*页面*/;

int k,j,ram,t;

float rate;/*缺页率*/

struct s1

{ int page;

int free;

int tag;

} fifo[33],opt[33],lru[33];

struct s2

{ int time;

};

void address();

float FIFO(int ram);/*先进先出*/

float LRU(int ram);/*最近最久未使用页面置换*/

void address() /*产生指令地址*/

{ int i;

add[0]=1000;

for (i=1; i<=255; i++)

{ int x=random(1024);

if ((x>=0)&&(x<512))

add[i]=add[i-1]+1;

if ((x>=512)&&(x<768))

add[i]=random(add[i-1]-1)+1;

if ((x>=768)&&(x<1024))

add[i]=add[i-1]+random(30*1024-add[i-1]-1)+1; }

}

float FIFO(int ram)

{ int absent=0,t=0,i,z,l,yn;

for (i=0; i

{ fifo[i].page=-1;

fifo[i].free=1;

fifo[i].tag=0;

}

i=0;

while (i

{ yn=0;

for (z=0; z

if (fifo[z].page==page[i])

{yn=1;

for (z=0; z

if (fifo[z].free==0)

fifo[z].tag+=1;

}

if (yn!=1)

{ absent+=1; /*count the absent page*/

l=0;

while ((l

l++;

if ((l

{ fifo[l].page=page[i];

fifo[l].free=0;

for (l=0; l

if (fifo[l].free==0 )

fifo[l].tag+=1;

}

else /*there is no free ram*/

{ t=0;

for (l=0; l

if ( fifo[l].tag

t=l;

fifo[t].page=page[i];

fifo[t].free=0;

fifo[t].tag=1;

l=0;

}

}

i++;

}

rate=(float)absent/j*100;

return rate;

}

float LRU(int ram)

{ int absent=0,yn,t,i,l,z,now=0;

struct s2 P[250];

for (i=0;i

P[i].time=0;

for (i=0; i

{ lru[i].page=-1;

lru[i].free=1;

}

i=0;

while(i

{ for(l=0; l

yn=0;

{ for(z=0; z

if (lru[z].page==page[i])

{ now+=1;

P[lru[z].page].time=now;

yn=1;

}

if (yn!=1)

{ absent+=1; now+=1;

l=0;

while ((l<=ram)&&(lru[l].free==0))

l++;

if ((l<=ram)&&(lru[l].free==1)) /*any free ram?*/

{ lru[l].page=page[i];

P[lru[l].page].time=now;

相关文档
最新文档