计算机操作系统缺页率计算,计算机操作系统实验模拟比较页面置换页算法附缺页率().doc...

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

成绩

计算机操作系统实验

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

学 号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;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值