- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
操作系统3100717102周杰
桂 林 理 工 大 学
实 验 报 告
班级 计算机10-1 学号 31007171002 姓名 周杰 同组实验者
实验名称 存储管理算法实验 日期 2012年 11 月 15日
一、实验目的:
存储管理的主要功能之一是合理地分配空间。请求页式管理是一种常用的虚拟存储管理技术。
本实验的目的是通过请求页式存储管理中页面置换算法模拟设计,了解虚拟存储技术的特点,掌握请求页式管理的页面置换算法。
二、实验内容:
1.通过随机数产生一个指令序列,共320条指令。其地址按下述原则生成:
①50%的指令是顺序执行的;
②25%的指令是均匀分布在前地址部分;
③25%的指令是均匀分布在后地址部分;
#具体的实施方法是:
A. 在[0,319]的指令地址之间随机选取一起点M;
B. 顺序执行一条指令,即执行地址为M+1的指令;
C. 在前地址[0,M+1]中随机选取一条指令并执行,该指令的地址为M’;
D. 顺序执行一条指令,其地址为M’+1;
E. 在后地址[M’+2,319]中随机选取一条指令并执行;
F. 重复A—E,直到执行320次指令。
2.指令序列变换成页地址流
设: (1)页面大小为1K;
(2)用户内存容量为4页到32页;
(3)用户虚存容量为32K。
在用户虚存中,按每K存放10条指令排列虚存地址,即320条指令在虚存中的存放方式为:
第0条—第9条指令为第0页(对应虚存地址为[0,9]);
第10条—第19条指令为第1页(对应虚存地址为[10,19]);
。。。。。。。。。。。。。。。。。。。。。
第310条—第319条指令为第31页(对应虚存地址为[310,319]);
按以上方式,用户指令可组成32页。
3. 计算并输出下述各种算法在不同内存容量下的命中率。
A. FIFO先进先出的算法
B. LRR最近最少使用算法
C. OPT最佳淘汰算法(先淘汰最不常用的页地址)
三、程序清单:
#includestdio.h
#includeiostream.h
#include stdlib.h
#includetime.h
#includeiomanip.h
struct aa{
int page,count;
aa* next; };
void main()
{
time_t t;
srand(unsigned(time(t))); //随机数发生器初始化
int i,n,j,ii,m,answer,ffalse,count,fangfa,temp1,min,nn,mm;
float sum;
aa *head,*tail,*temp,*table,*first,*ti;
//nn=4;mm=1;
coutfangfa: 1-FIFO;2-LRR;3-OPT endl;
coutPage ;
coutFIFO ;
cout LRR ;
cout OPT endl;
for(nn=4;nn32;nn++)
{
m=nn;
coutnn ;
if(nn10) cout ;
for(mm=1;mm4;mm++)
{
//cinm;
//coutendl;
//cinfangfa;
fangfa=mm;
ffalse=0;
answer=0;
table=new(aa);
temp=table;
table-page=-1;
table-count=0;
head=table;
for(ii=2;ii=m;ii++)
{
table=new(aa);
table-page=-1;
table-count=0;
temp-next=table;
temp=table;
if (ii==m){table-next=NULL;}
}
tail=table;
temp=head;
first=head;
count=0;
i=0;
while(i320) {
if (count==0) {n=(rand()%320+1)%320; j=n/10;}
if (count==1) {n=rand()%(n+1);j=n/10;}
if(count==2) {j=((n+1)%320)/10;}
if(count==3) {j=((ran
您可能关注的文档
- 钱宝军八年级课件1 Unit6_How_long_have_you_been_collecting_shells.ppt
- C++上机指导(第12次实验)(附答案).doc
- DS18B20测温计LCD显(经ISIS仿真验证).doc
- 人教版初二八年级下册英语《Unit 6 How long have you been collecting shells PPT课件》.ppt
- 《程序设计与问题求解II》实验指导书修订v1.2.doc
- 面向对象编程教程 王育坚VC 第2版 第二章课后习题.doc
- 八年级英语上册_Unit_9_When_was_he_born_Section_A课件_人教新目标版.ppt
- 八上仁爱比较级专项训练.pptx
- 2011年1月自考C++考试题.doc
- 2014年人教版新目标八年级下Unit7-Section-A-1课件(修改).ppt
- html+css2.1总结.docx
- 新目标英语八年级下Unit 6 Section A.ppt
- 人教新目标八年级英语下册 课件:Unit 7 Section A Period 1(1a-2d)(共48张PPT).ppt
- 2010上全国信息技术水平考试计算机程序设计技术水平证书(C语言).doc
- 八年级英语下册《Unit7 What’s the highest mountain in the world》Section A-1.ppt
- 3-2选择结构.doc
- 限时集训(二十一) Fit for life.doc
- 八年级下册人教版英语 How long have you been collecting shells?A.ppt
- 第2章:C语言初步知识.ppt
- 第2章数据类型与运算规则.ppt
文档评论(0)