版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、广州大学学生实验报告开课学院及实验室:计算机科学与工程实验室 2015 年 11月 29 日实验课程名称操作系统实验成绩实验项目名称实验3 内存管理 指导老师一、实验目的通过模拟实现请求页式存储管理的几种基本页面置换算法,了解虚拟存储技术的特点,掌握虚拟存储请求页式存储管理中几种基本页面置换算法的基本思想和实现过程,并比较它们的效率。2、 实验内容1、常用页面置换算法模拟实验 设计一个虚拟存储区和内存工作区,并使用下述算法计算访问命中率。1)、最佳淘汰算法(OPT)2)、先进先出的算法(FIFO)3)、最近最久未使用算法(LRU)4)、最不经常使用算法(LFU)5)、最近未使用算法(NUR)命
2、中率页面失效次数页地址流长度2、在Linux环境下利用下列系统调用malloc(), free()编写一段程序实现内存分配与回收的管理。要求:1)、返回已分配给变量的内存地址;2)、返回释放后的内存地址;3)、释放已分配的内存空间后,返回释放内存后未使用内存的大小。三、实验原理一、虚拟存储系统UNIX中,为了提高内存利用率,提供了内外存进程对换机制;内存空间的分配和回收均以页为单位进行;一个进程只需将其一部分(段或页)调入内存便可运行;还支持请求调页的存储管理方式。当进程在运行中需要访问某部分程序和数据时,发现其所在页面不在内存,就立即提出请求(向CPU发出缺中断),由系统将其所需页面调入内存
3、。这种页面调入方式叫请求调页。为实现请求调页,核心配置了四种数据结构:页表、页框号、访问位、修改位、有效位、保护位等。二、页面置换算法当CPU接收到缺页中断信号,中断处理程序先保存现场,分析中断原因,转入缺页中断处理程序。该程序通过查找页表,得到该页所在外存的物理块号。如果此时内存未满,能容纳新页,则启动磁盘I/O将所缺之页调入内存,然后修改页表。如果内存已满,则须按某种置换算法从内存中选出一页准备换出,是否重新写盘由页表的修改位决定,然后将缺页调入,修改页表。利用修改后的页表,去形成所要访问数据的物理地址,再去访问内存数据。整个页面的调入过程对用户是透明的。常用的页面置换算法有1、最佳置换算
4、法(Optimal)2、先进先出法(Fisrt In First Out)3、最近最久未使用(Least Recently Used)4、最不经常使用法(Least Frequently Used)5、最近未使用法(No Used Recently)四、实验设备Win7下虚拟机VMware-workstation-11.0.0及CentOS-5.8-i3865、 实验要求 书写实验报告。提交实验报告。报告主要以操作结果以及分析回答实验中问题为主,可以以截图进行说明。六、实验程序 T4:#include<stdio.h>#include<stdlib.h>#define
5、TRUE 1#define FALSE 0#define INVALID -1#define total_instruction 320 /*指令流长*/#define total_vp 32 /*虚页长*/#define clear_period 50 /*清0周期*/typedef struct /*页面结构*/int pn,pfn,counter,time;pl_type;pl_type pltotal_vp; /*页面结构数组*/struct pfc_struct /*页面控制结构*/int pn,pfn;struct pfc_struct *next;typedef struct p
6、fc_struct pfc_type;pfc_type pfctotal_vp,*freepf_head,*busypf_head,*busypf_tail;int diseffect, atotal_instruction;int pagetotal_instruction, offsettotal_instruction;int initialize(int);int FIFO(int);int LRU(int);int LFU(int);int NUR(int);int OPT(int);int main() int s,i,j; srand(10*getpid(); /*由于每次运行时
7、进程号不同,故可用来作为初始化随机数队列的“种子”*/s=(float)319*rand()/32767/32767/2+1; /for(i=0;i<total_instruction;i+=4) /*产生指令队列*/ if(s<0|s>319) printf("When i=%d,Error,s=%dn",i,s); exit(0); ai=s; /*任选一指令访问点m*/ ai+1=ai+1; /*顺序执行一条指令*/ ai+2=(float)ai*rand()/32767/32767/2; /*执行前地址指令m' */ ai+3=ai+2+1
8、; /*顺序执行一条指令*/ s=(float)(318-ai+2)*rand()/32767/32767/2+ai+2+2; if(ai+2>318)|(s>319) printf("a%d+2,a number which is :%d and s=%dn",i,ai+2,s);for (i=0;i<total_instruction;i+) /*将指令序列变换成页地址流*/ pagei=ai/10; offseti=ai%10;for(i=4;i<=32;i+) /*用户内存工作区从4个页面到32个页面*/ printf("-%2d
9、page frames-n",i); FIFO(i); LRU(i); LFU(i); NUR(i); OPT(i); return 0;int initialize(total_pf) /*初始化相关数据结构*/int total_pf; /*用户进程的内存页面数*/int i;diseffect=0;for(i=0;i<total_vp;i+) pli.pn=i; pli.pfn=INVALID; /*置页面控制结构中的页号,页面为空*/ pli.counter=0; pli.time=-1; /*页面控制结构中的访问次数为0,时间为-1*/for(i=0;i<tot
10、al_pf-1;i+) pfci.next=&pfci+1; pfci.pfn=i; /*建立pfci-1和pfci之间的链接*/pfctotal_pf-1.next=NULL;pfctotal_pf-1.pfn=total_pf-1;freepf_head=&pfc0; /*空页面队列的头指针为pfc0*/return 0;int FIFO(total_pf) /*先进先出算法*/int total_pf; /*用户进程的内存页面数*/ int i,j; pfc_type *p; initialize(total_pf); /*初始化相关页面控制用数据结构*/ busypf_
11、head=busypf_tail=NULL; /*忙页面队列头,队列尾链接*/ for(i=0;i<total_instruction;i+) if(plpagei.pfn=INVALID) /*页面失效*/ diseffect+=1; /*失效次数*/ if(freepf_head=NULL) /*无空闲页面*/ p=busypf_head->next; plbusypf_head->pn.pfn=INVALID; freepf_head=busypf_head; /*释放忙页面队列的第一个页面*/ freepf_head->next=NULL; busypf_hea
12、d=p; p=freepf_head->next; /*按FIFO方式调新页面入内存页面*/ freepf_head->next=NULL; freepf_head->pn=pagei; plpagei.pfn=freepf_head->pfn;if(busypf_tail=NULL) busypf_head=busypf_tail=freepf_head; else busypf_tail->next=freepf_head; /*free页面减少一个*/ busypf_tail=freepf_head; freepf_head=p; printf("
13、FIFO:%6.4fn",1-(float)diseffect/320);return 0;int LRU (total_pf) /*最近最久未使用算法*/int total_pf; int min,minj,i,j,present_time; initialize(total_pf); present_time=0;for(i=0;i<total_instruction;i+) if(plpagei.pfn=INVALID) /*页面失效*/ diseffect+; if(freepf_head=NULL) /*无空闲页面*/ min=32767; for(j=0;j<
14、total_vp;j+) /*找出time的最小值*/ if(min>plj.time&&plj.pfn!=INVALID) min=plj.time; minj=j; freepf_head=&pfcplminj.pfn; /腾出一个单元 plminj.pfn=INVALID; plminj.time=-1; freepf_head->next=NULL; plpagei.pfn=freepf_head->pfn; /有空闲页面,改为有效 plpagei.time=present_time;freepf_head=freepf_head->ne
15、xt; /减少一个free 页面 else plpagei.time=present_time; /命中则增加该单元的访问次数 present_time+; printf("LRU:%6.4fn",1-(float)diseffect/320);return 0;int NUR(total_pf) /*最近未使用算法*/int total_pf; int i,j,dp,cont_flag,old_dp;pfc_type *t;initialize(total_pf);dp=0;for(i=0;i<total_instruction;i+) if (plpagei.pf
16、n=INVALID) /*页面失效*/ diseffect+; if(freepf_head=NULL) /*无空闲页面*/ cont_flag=TRUE; old_dp=dp; while(cont_flag) if(pldp.counter=0&&pldp.pfn!=INVALID) cont_flag=FALSE; else dp+; if(dp=total_vp) dp=0; if(dp=old_dp) for(j=0;j<total_vp;j+) plj.counter=0; freepf_head=&pfcpldp.pfn; pldp.pfn=INVA
17、LID; freepf_head->next=NULL; plpagei.pfn=freepf_head->pfn; freepf_head=freepf_head->next; else plpagei.counter=1; if(i%clear_period=0) for(j=0;j<total_vp;j+) plj.counter=0;printf("NUR:%6.4fn",1-(float)diseffect/320);return 0;int OPT(total_pf) /*最佳置换算法*/int total_pf;int i,j, max
18、,maxpage,d,disttotal_vp;pfc_type *t;initialize(total_pf);for(i=0;i<total_instruction;i+) /printf("In OPT for 1,i=%dn",i); /i=86;i=176;206;250;220,221;192,193,194;258;274,275,276,277,278; if(plpagei.pfn=INVALID) /*页面失效*/ diseffect+; if(freepf_head=NULL) /*无空闲页面*/ for(j=0;j<total_vp;j+
19、) if(plj.pfn!=INVALID) distj=32767; /* 最大"距离" */ else distj=0; d=1; for(j=i+1;j<total_instruction;j+) if(plpagej.pfn!=INVALID) distpagej=d; d+; max=-1; for(j=0;j<total_vp;j+) if(max<distj) max=distj; maxpage=j; freepf_head=&pfcplmaxpage.pfn; freepf_head->next=NULL; plmaxpag
20、e.pfn=INVALID; plpagei.pfn=freepf_head->pfn; freepf_head=freepf_head->next; printf("OPT:%6.4fn",1-(float)diseffect/320);return 0;int LFU(total_pf) /*最不经常使用置换法*/int total_pf; int i,j,min,minpage; pfc_type *t; initialize(total_pf); for(i=0;i<total_instruction;i+) if(plpagei.pfn=INVA
21、LID) /*页面失效*/ diseffect+; if(freepf_head=NULL) /*无空闲页面*/ min=32767; for(j=0;j<total_vp;j+) if(min>plj.counter&&plj.pfn!=INVALID) min=plj.counter; minpage=j; plj.counter=0; freepf_head=&pfcplminpage.pfn; plminpage.pfn=INVALID; freepf_head->next=NULL; plpagei.pfn=freepf_head->p
22、fn; /有空闲页面,改为有效 plpagei.counter+; freepf_head=freepf_head->next; /减少一个free 页面 else plpagei.counter+; printf("LFU:%6.4fn",1-(float)diseffect/320);return 0;T5程序:/* For _MAX_PATH definition */#include <malloc.h>#include<stdio.h>#include<stdlib.h>int main() int *string; /* Allocate space for a path name */ string=(int*) malloc(10); if(string = NULL) printf("Insufficient memory availablen"); else print
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 线上课程设计 动画
- 药学课程设计指南
- 机设课程设计的模板
- 网络服务器配置课程设计
- 捅马蜂窝课程设计
- 智能可穿戴手表课程设计
- 2024年职业生涯规划教案篇
- 药品检验类课程设计论文
- 2024年移动智慧家庭工程师(高级)资格认证考试题库-上(选择题)
- 物流运输行业营销工作总结
- 2024年度陶瓷产品代理销售与品牌战略合作协议3篇
- 中国农业银行信用借款合同
- ISO 56001-2024《创新管理体系-要求》专业解读与应用实践指导材料之9:“5领导作用-5.3创新战略”(雷泽佳编制-2025B0)
- 2024版旅游景区旅游巴士租赁合同3篇
- LINUX网络操作系统知到智慧树章节测试课后答案2024年秋湖北交通职业技术学院
- 河北省邯郸市2023-2024学年高一上学期期末质量检测地理试题 附答案
- 医疗机构竞业限制协议
- 2024年度物业管理公司员工奖惩制度3篇
- 2024年7月国家开放大学法学本科《知识产权法》期末考试试题及答案
- 2024年河南省公务员录用考试《行测》试题及答案解析
- (2024年)剪映入门教程课件
评论
0/150
提交评论