【报告】页面置换算法模拟实验报告材料.docx

【报告】页面置换算法模拟实验报告材料.docx

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 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)

小橙学习资料 + 关注
实名认证
内容提供者

学习资料 欢迎下载

1亿VIP精品文档

相关文档