(LRU)置换算法-操作系统

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

实验报告三

——内存页面置换算法的设计

姓名:田玉祥

班级:计算机科学与技术专业一班

一、实验内容

·实现最近最久未使用(LRU)置换算法

二、实验目的

•LINUX中,为了提高内存利用率,提供了内外存进程对换机制,内存空间的分配和回收均以页为单位进行,一个进程只需将其

一部分调入内存便可运行,还支持请求调页的存储管理方式。

•本实习要求学生通过请求页式存储管理中页面置换算法模拟设计,了解虚拟存储技术的特点,掌握请求页式存储管理的页面

置换算法。

三、实验题目

1. 最近最久未使用(LRU)置换算法原理就是:当需要淘汰某页

面时,选择当前一段时间内最久未使用过的页先淘汰,即淘汰距当前最远的上次使用的页。

•例如: 分配给该进程的页块数为3,一个20位长的页面访问序列为:12560,36536,56042,70435,

则缺页次数和缺页率按下图给出:

假定分配给该进程的页块数为3,页面访问序列长度为20。本实验可以采用数组结构实现,首先随机产生页面序列,当发生请求调页时,若内存已满,则需要利用LRU算法,将当前一段时间内最久未使用过的页替换出去。

程序实现想法:

用一个数组a[n]来存放所有需要访问的页,用一个数组b[3]来存放页表,用数组c[3]来存放页表每一页的权值,就是最近最少使用的度,度越高则使用率越小,用n次循环,每次a[i]进行判断时先判断有没有空格,再判断a[i]是否已经在页表中,此时注意要将权值归1,若都没有这些情况,则用函数int MAX(int a,int b,int c) 找到权值最大的,进行替换,并将其他页的权值加1.

实验代码:

//LRU算法,最近最少使用的页替换算法

#include

#include

using namespace std ;

int MAX(int a,int b,int c) //赋值之后的权值中找到权值最大的,返回它的下标也就是最近最少使用的

{

int max = a ;

if(max

{

max = b ;

if(max

max = c ;

}

else

if(max

max = c ;

if(a==max) //找到权值最大的数的下标

return 0 ;

else if(b==max)

return 1 ;

else if(c==max)

return 2 ;

}

int main()

{

// string k ; //k表示当前最近最少使用的页;

int i,j,n,l,m,p,q ; //j表示当前访问的页是否已经在访问,0表示没有发生缺页,1表示发生缺页

//q来表示页表是否有空格,即当前是否全部在使用,1表示全部在使用,0表示还有空格

string *b = new string [3] ; //存放页表

int *c = new int [3] ; //存放页表的权值

for(i=0;i<3;i++)

{

b[i] = " " ;

c[i] = 1 ;

}

cout<<"请输入要访问的页码页数:"<

cin >> n ;

string *a = new string [n] ; //存放所有要访问的页

cout<<"请输入"<

for(i=0;i

cin>>a[i] ;

cout<<"页表访问过程如下,“1”表示发生缺页,“0”表示不发生缺页:"<

{

j = 1 ;

q = 1 ; //表示页表没有空位,全被使用

for(l=0;l<3;l++)

if(a[i]==b[l])

{

j = 0 ;

c[l]=1 ; //将权值设为1

c[l-1]++;

c[l-2]++;

c[l+1]++;

c[l+2]++;

break ;

}

if(j==0) //如果需要访问的页正在被访问,即已经在页表,直接输出。并将其权值设为1

{

for(l=0;l<3;l++)

cout<

cout<

}

//如果访问的页发生缺页有两种情况

if(j==1) //第一种,页表有空闲帧

for(l=0;l<3;l++)

{

if(b[l]==" ")

{

b[l]=a[i] ;

c[l-1]++ ;

c[l-2]++ ;

for(p=0;p<3;p++)

cout<

cout<

q = 0 ;

break ;

}

}

if(j==1&&q==1) //须要访问的页不在页表中

{

m = MAX(c[0],c[1],c[2]) ;

b[m]=a[i] ;

c[m]=1 ;

c[m-1]++;

c[m-2]++;

c[m+1]++;

c[m+2]++;

for(p=0;p<3;p++)

cout<

cout<

}

}

system("pause") ;

return 0 ;

}

代码实现:

相关文档
最新文档