- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
试验编号 4 名称页面置换算法模拟
试验目的
|精.
|品.
|可.
|编.
|辑.
|学.
|习.
|资.
|料.
*
|
*
|
*
|
*
|
|欢.
|迎.
|下.
|载.
通过恳求页式储备治理中页面置换算法模拟设计,以便:
1、明白虚拟储备技术的特点
2、把握恳求页式储备治理中页面置换算法
试验内容与步骤
设计一个虚拟储备区和内存工作区,并使用 FIFO 和 LRU 算法运算拜访命中率;
程序设计
先用 srand()函数和 rand() 函数定义和产生指令序列, 然后将指令序列变换成相应的页地址流,并针对不同的算法运算相应的命中率;
程序 1
#include windows.h //Windows 版,随机函数需要, GetCurrentProcessId() 需要
//#include stdlib.h //Linux 版,随机函数 srand 和 rand 需要
#include stdio.h //printf() 需要
#define TRUE 1
#define FALSE 0 #define INV ALID -1 #define NULL 0
#define total_instruction 320 //共 320 条指令
#define total_vp 32 // 虚存页共 32 页
#define clear_period 50 // 拜访次数清零周期
typedef struct{ // 定义页表结构类型〔页面映射表 PMT 〕
int pn, pfn, counter, time; // 页号、页框号 (块号 )、一个周期内拜访该页面的次数、拜访时
间
}PMT;
PMT pmt[32];
typedef struct pfc_struct{ // 页面掌握结构
int pn, pfn;
struct pfc_struct *next;
}pfc_type; pfc_type pfc[32];
pfc_type *freepf_head,*busypf_head,*busypf_tail; //闲暇页头指针,忙页头指针,忙页尾指针
int NoPageCount; // 缺页次数
int a[total_instruction]; // 指令流数组
int page[total_instruction], offset[total_instruction]; // 每条指令的页和页内偏移
|精.
|品.
|可.
|编.
|辑.
|学.
|习.
|资.
|料.
*
|
*
|
*
|
*
|
|欢.
|迎.
|下.
|载.
void initialize( int );
void FIFO( int ); //先进先出void LRU( int ); //最近最久未使用
void NRU( int ); // 最近最不常常使用
/****************************************************************************
main()
*****************************************************************************/ void main(){
int i,s;
//srand(10*getpid()); //用进程号作为初始化随机数队列的种子 //Linux 版
srand(10*GetCurrentProcessId()); // 用进程号作为初始化随机数的种子 //Windows 版
s=rand()%320; //在[0 , 319] 的指令地址之间随机选取一起点 m for(i=0;itotal_instruction;i+=4){ // 产生指令队列
if(s0||s319){
printf(when i==%d,error,s==%d\n,i,s); exit(0);
}
a[i]=s; //任意选一指令拜访点 m;〔将随机数作为指令地址 m〕a[i+1]=a[i]+1; // 次序执行下一条指令
a[i+2]=rand()%(s+2); //在[0 , m+1] 的前地址之间随机选取一地址,记为 m
a[i+3]=a[i+2]+1; //次序执行一条指令
s = a[i+2] + (int)rand()%(320-a[i+2]); // 在[m ,319] 的指令地址之间随机选取一起点 m if((a[i+2]318)||(s319)) printf(a[%d+2,a number which is:%d and s=%d\n,i,a[i+2],s);
}
for(i=0;itotal_instruction;i++){ //将指
原创力文档


文档评论(0)