- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
实用标准文案
精彩文档
实验编号 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 INVALID -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++){//将指令序列变成页地址流
page[i]=a[i]/10;
offset[i]=a[i]%10;
}
for(i=4;i=32;i++){//内存块分别为4块、5块、...32块时的命中率
printf(%2d page f
文档评论(0)