ImageVerifierCode 换一换
格式:DOCX , 页数:15 ,大小:108.02KB ,
资源ID:28091025      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/28091025.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(存储管理实验报告.docx)为本站会员(b****8)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

存储管理实验报告.docx

1、存储管理实验报告综合性实验报告专业:网络工程 年级:12级 班级: 网络工程 20142015学年第一学期课程名称计算机操作系统指导教师实验地点过街楼实验时间12.3-12.10-12.17-12.2412.4-12.11-12.18-12.25项目名称存储管理实验类型综合性一、 实验目的通过请求页式存储管理中页面置换算法模拟设计,了解虚拟存储技术的特点,掌握请求页式管理的页面置换算法。页面置换算法是虚拟存储管理实现的关键,通过本次实验理解内存页面调度的机制,在模拟实现FIFO、LRU、OPT、LFU、NUR几种经典页面置换算法的基础上,比较各种置换算法的效率及优缺点,从而了解虚拟存储实现的过

2、程。二、 总体设计1、编写函数计算并输出下述各种算法的命中率1 OPT页面置换算法OPT所选择被淘汰的页面是已调入内存,且在以后永不使用的,或是在最长时间内不再被访问的页面。因此如何找出这样的页面是该算法的关键。可为每个页面设置一个步长变量,其初值为一足够大的数,对于不在内存的页面,将其值重置为零,对于位于内存的页面,其值重置为当前访问页面与之后首次出现该页面时两者之间的距离,因此该值越大表示该页是在最长时间内不再被访问的页面,可以选择其作为换出页面。2 FIFO页面置换算法FIFO总是选择最先进入内存的页面予以淘汰,因此可设置一个先进先出的忙页帧队列,新调入内存的页面挂在该队列的尾部,而当无

3、空闲页帧时,可从该队列首部取下一个页帧作为空闲页帧,进而调入所需页面。3 LRU页面置换算法LRU是根据页面调入内存后的使用情况进行决策的,它利用“最近的过去”作为“最近的将来”的近似,选择最近最久未使用的页面予以淘汰。该算法主要借助于页面结构中的访问时间time来实现,time记录了一个页面上次的访问时间,因此,当须淘汰一个页面时,选择处于内存的页面中其time值最小的页面,即最近最久未使用的页面予以淘汰。4 LFU页面置换算法LFU要求为每个页面配置一个计数器(即页面结构中的counter),一旦某页被访问,则将其计数器的值加1,在需要选择一页置换时,则将选择其计数器值最小的页面,即内存中

4、访问次数最少的页面进行淘汰。5 NUR页面置换算法NUR要求为每个页面设置一位访问位(该访问位仍可使用页面结构中的counter表示),当某页被访问时,其访问位counter置为1。需要进行页面置换时,置换算法从替换指针开始(初始时指向第一个页面)顺序检查处于内存中的各个页面,如果其访问位为0,就选择该页换出,否则替换指针下移继续向下查找。如果内存中的所有页面扫描完毕未找到访问位为0的页面,则将替换指针重新指向第一个页面,同时将内存中所有页面的访问位置0,当开始下一轮扫描时,便一定能找到counter为0的页面。2、 在主函数中生成要求的指令序列,并将其转换成页地址流;在不同的内存容量下调用上

5、述函数使其计算并输出相应的命中率。三、 实验步骤(包括主要步骤、代码分析等)主要步骤:、通过随机数产生一个指令序列,共320条指令。其地址按下述原则生成:50%的指令是顺序执行的;25%的指令是均匀分布在前地址部分;25%的指令是均匀分布在后地址部分;具体的实施方法是:A.在0,319的指令地址之间随机选区一起点M;B.顺序执行一条指令,即执行地址为M+1的指令;C.在前地址0,M+1中随机选取一条指令并执行,该指令的地址为M;D.顺序执行一条指令,其地址为M+1;E.在后地址M+2,319中随机选取一条指令并执行;F.重复AE,直到执行320次指令。2、指令序列变换成页地址流,设:页面大小为

6、1K;用户内存容量为4页到32页;用户虚存容量为32K。在用户虚存中,按每页存放10条指令排列虚存地址,即320条指令在虚存中的存放方式为:第0条第9条指令为第0页(对应虚存地址为0,9);第10条第19条指令为第1页(对应虚存地址为10,19);第310条第319条指令为第31页(对应虚存地址为310,319);按以上方式,用户指令可组成32页。3、计算并输出下述各种算法(可任选两个)在不同内存容量下的命中率。A. FIFO先进先出置换算法;B. LRU最近最久未使用置换算法;C. OPT最佳置换算法:先淘汰最不常用的页地址;D. NUR最近未使用置换算法;E. LFU最少使用置换算法。命中

7、率=1-页面失效次数/页地址流长度在本实验中,页地址流长度为320,页面失效次数为每次访问相应指令时,该指令所对应的页不在内存的次数。代码分析:1、主函数main.cpp的代码:#include #include #include #include #include #include using namespace std;#define INVALID -1const int TOTAL_INSTRUCTION(320);const int TOTAL_VP(32);const int CLEAR_PERIOD(50);#include Page.h#include PageControl.

8、h#include Memory.hint main() int i; CMemory a; for(i=4;i=32;i+) couti page frames t; a.OPT(i); a.FIFO(i); a.LRU(i); coutn; return 0;2、主函数中用到的头文件”Page.h”,”PageControl.h”,”Memory.h”的代码:Page.h:#ifndef _PAGE_H#define _PAGE_Hclass CPage/页面结构public: int m_nPageNumber,/页面号 m_nPageFaceNumber,/页帧号 m_nCounter

9、,/一个周期内访问该页面的次数 m_nTime;/访问时间;#endifPageControl.h:#ifndef _PAGECONTROL_H#define _PAGECONTROL_Hclass CPageControl/页帧控制结构public: int m_nPageNumber,m_nPageFaceNumber; class CPageControl * m_pNext;#endifMemory.h:#ifndef _MEMORY_H#define _MEMORY_Hclass CMemorypublic: CMemory(); void initialize(const int

10、nTotal_pf); void OPT(const int nTotal_pf); void FIFO(const int nTotal_pf); void LRU(const int nTotal_pf); private: vector _vDiscPages; vector _vMemoryPages; CPageControl *_pFreepf_head,*_pBusypf_head,*_pBusypf_tail; vector _vMain,_vPage,_vOffset; int _nDiseffect; ;CMemory:CMemory():_vDiscPages(TOTAL

11、_VP), _vMemoryPages(TOTAL_VP), _vMain(TOTAL_INSTRUCTION), _vPage(TOTAL_INSTRUCTION), _vOffset(TOTAL_INSTRUCTION) int S,i,nRand; srand(getpid()*10); nRand=rand()%32767; S=(float)319*nRand/32767+1; for(i=0;iTOTAL_INSTRUCTION;i+=4) _vMaini=S; _vMaini+1=_vMaini+1; nRand=rand()%32767; _vMaini+2=(float)_v

12、Maini*nRand/32767; _vMaini+3=_vMaini+2+1; nRand=rand()%32767; S=(float)nRand *(318-_vMaini+2)/32767+_vMaini+2+2; for(i=0;iTOTAL_INSTRUCTION;i+) _vPagei=_vMaini/10; _vOffseti=_vMaini%10; _vPagei%=32; void CMemory:initialize(const int nTotal_pf) int ix; _nDiseffect=0; for(ix=0;ix_vDiscPages.size();ix+

13、) _vDiscPagesix.m_nPageNumber=ix; _vDiscPagesix.m_nPageFaceNumber=INVALID; _vDiscPagesix.m_nCounter=0; _vDiscPagesix.m_nTime=-1; for(ix=1;ixnTotal_pf;ix+) _vMemoryPagesix-1.m_pNext=&_vMemoryPagesix; _vMemoryPagesix-1.m_nPageFaceNumber=ix-1; _vMemoryPagesnTotal_pf-1.m_pNext=NULL; _vMemoryPagesnTotal_

14、pf-1.m_nPageFaceNumber=nTotal_pf-1; _pFreepf_head=&_vMemoryPages0;void CMemory:OPT(const int nTotal_pf) /* 最佳页面置换算法 */ int i,j,max,maxpage,d,distTOTAL_VP; initialize(nTotal_pf); for(i=0;iTOTAL_INSTRUCTION;i+) if(_vDiscPages_vPagei.m_nPageFaceNumber=INVALID) /*页面失效*/ _nDiseffect+; if(_pFreepf_head=NU

15、LL) /*无空闲页面*/ for(j=0;jTOTAL_VP;j+) if(_vDiscPagesj.m_nPageFaceNumber!=INVALID)/所有位于内存页面的距离变量赋一足够大的数 distj=32767; else /不在内存的页面该变量则置为0 distj=0; d=1; /* 对于位于内存且在当前访问页面之后将再次被访问的页面,dist重置为当 前页 面与之后首次出现该页面时两者之间的距离 */ for(j=i+1;jTOTAL_INSTRUCTION;j+) if(_vDiscPages_vPagej.m_nPageFaceNumber!=INVALID & dis

16、t_vPagej=32767) dist_vPagej=d; d+; max=-1; /查找dist变量值最大的页面作为换出页面 for(j=0;jTOTAL_VP;j+) if(maxm_pNext=NULL; _vDiscPagesmaxpage.m_nPageFaceNumber=INVALID; _vDiscPages_vPagei.m_nPageFaceNumber=_pFreepf_head-m_nPageFaceNumber; /有空闲页面,改为有效 _pFreepf_head=_pFreepf_head-m_pNext; /减少一个free 页面 coutOPT: 1-(flo

17、at)_nDiseffect/320; /printf(OPT:%6.4f ,1-(float)diseffect/320);void CMemory:FIFO(const int nTotal_pf) int i; CPageControl *p; initialize(nTotal_pf); _pBusypf_head=_pBusypf_tail=NULL; for(i=0;im_pNext; _vDiscPages_pBusypf_head-m_nPageNumber.m_nPageFaceNumber=INVALID; _pFreepf_head=_pBusypf_head; _pFr

18、eepf_head-m_pNext=NULL; _pBusypf_head=p; p=_pFreepf_head-m_pNext; _pFreepf_head-m_pNext=NULL; _pFreepf_head-m_nPageNumber=_vPagei; _vDiscPages_vPagei.m_nPageFaceNumber=_pFreepf_head-m_nPageFaceNumber; if(_pBusypf_tail=NULL) _pBusypf_head=_pBusypf_tail=_pFreepf_head; else _pBusypf_tail-m_pNext=_pFree

19、pf_head; _pBusypf_tail=_pFreepf_head; _pFreepf_head=p; couttFIFO: 1-(float)_nDiseffect/320;void CMemory:LRU(const int nTotal_pf) int i,j,nMin,minj,nPresentTime(0); initialize(nTotal_pf); for(i=0;iTOTAL_INSTRUCTION;i+) if(_vDiscPages_vPagei.m_nPageFaceNumber=INVALID) _nDiseffect+; if(_pFreepf_head=NU

20、LL) nMin=32767; for(j=0;j_vDiscPagesj.m_nTime&_vDiscPagesj.m_nPageFaceNumber!=INVALID) nMin=_vDiscPagesj.m_nTime; minj=j; _pFreepf_head=&_vMemoryPages_vDiscPagesminj.m_nPageFaceNumber; _vDiscPagesminj.m_nPageFaceNumber=INVALID; _vDiscPagesminj.m_nTime=-1; _pFreepf_head-m_pNext=NULL; _vDiscPages_vPag

21、ei.m_nPageFaceNumber=_pFreepf_head-m_nPageFaceNumber; _vDiscPages_vPagei.m_nTime=nPresentTime; _pFreepf_head=_pFreepf_head-m_pNext; else _vDiscPages_vPagei.m_nTime=nPresentTime; nPresentTime+; couttLRU: 1-(float)_nDiseffect/320;#endif四、 结果分析与总结实验运行结果,如图:总结:从上述结果可知,随着内存页面数的增加,三种算法的访问命中率逐渐增大。在内存页面数为425个页面之间时,三种算法的命中率大致在56%至88%之间变化,但是,OPT算法和其他两种算法之间的差别一般在612个百分点左右。在内存页面为2532个页面时,由于用户进程的所有指令基本上都已装入内存,从而命中率增加较大,各种算法之间的差别不大。比较上述三种算法,OPT算法的命中率最高,LRU算法和FIFO算法的命中率则较为接近。教师签名: 年 月 日

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1