C语言模拟LRU页面置换算法

2025-11-05 05:02:08

1、首先打开VC++6.0

C语言模拟LRU页面置换算法

2、选择文件,新建

C语言模拟LRU页面置换算法

3、选择C++ source file 新建一个空白文档

C语言模拟LRU页面置换算法

4、首先声明头文件和常量

#include<stdio.h>

#include<stdlib.h>

#define PAGENUM 6 /*主存中允许的最大的页数*/

#define MAXPAGENUM 15 /* 一个程序包含的最大页数*/

C语言模拟LRU页面置换算法

5、定义栈的结构  即置换器

typedef struct stack

{

int page[PAGENUM];

int head;

}PAGER;

C语言模拟LRU页面置换算法

6、定义一个置换器

PAGER pager;其实就是声明一个pager对象

C语言模拟LRU页面置换算法

7、栈的初始化

void InitPager()

{

int top = 0;

int i,j,tmp;

int r;

randomize();

r = random(MAXPAGENUM);

pager.page[top++] = r;

while(top < PAGENUM )

{

       randomize();

r = random(MAXPAGENUM);

for(j =0;j<top;j++)

{

if(r == pager.page[j])

{

break;

}

if(j == top-1)

pager.page[top++] = r;

}

}

pager.head = PAGENUM - 1;

}

C语言模拟LRU页面置换算法

8、栈中成员的移动,即移动页面的操作

void MovingPage(int Begin )

{

int i;

for(i = Begin; i < PAGENUM-1; i++)

{

pager.page[i]  = pager.page[i+1] ;

}

}

C语言模拟LRU页面置换算法

9、出栈操作,即 交换出页面的操作

void PopPage(int p)

{

MovingPage(p);

pager.head = PAGENUM - 2;

}

C语言模拟LRU页面置换算法

10、入栈操作 ,即换进新页面的操作

void PushPage(int page)

{

pager.head = PAGENUM-1;

pager.page[pager.head] = page;

}

C语言模拟LRU页面置换算法

11、/*打印主存中的页面*/

void printPager()

{

       int i;

printf("The pages in the pager is:");

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

{

printf(" %d ",pager.page[i]);

}

printf("\n");

}

C语言模拟LRU页面置换算法

12、处理页面的换进和换出

void PagingProcess()

{

int rdm;

int i;

randomize();

rdm = random(MAXPAGENUM);

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

{

if(rdm == pager.page[i])

{

printPager();

printf("The page [%d]  will be accessed\n",rdm);

PopPage(i);

PushPage(rdm);

printPager();

break;

}

if(i == PAGENUM-1)

{

printPager();

printf("The page [0]  will be paged out\n");

PopPage(0);

printf("The page [%d]  will be paged in\n",rdm);

PushPage(rdm);

printPager();

}

}

}

C语言模拟LRU页面置换算法

13、主函数

int main()

{

int i;

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

{

InitPager();

printf("ROUND %d:\n\n",i+1);

PagingProcess();

}

getch();

return 0;

}

C语言模拟LRU页面置换算法

声明:本网站引用、摘录或转载内容仅供网站访问者交流或参考,不代表本站立场,如存在版权或非法内容,请联系站长删除,联系邮箱:site.kefu@qq.com。
猜你喜欢