操作系统实验4-请求分页存储管理模拟实验剖析

上传人:今*** 文档编号:105900778 上传时间:2019-10-14 格式:DOCX 页数:11 大小:862.47KB
返回 下载 相关 举报
操作系统实验4-请求分页存储管理模拟实验剖析_第1页
第1页 / 共11页
操作系统实验4-请求分页存储管理模拟实验剖析_第2页
第2页 / 共11页
操作系统实验4-请求分页存储管理模拟实验剖析_第3页
第3页 / 共11页
操作系统实验4-请求分页存储管理模拟实验剖析_第4页
第4页 / 共11页
操作系统实验4-请求分页存储管理模拟实验剖析_第5页
第5页 / 共11页
点击查看更多>>
资源描述

《操作系统实验4-请求分页存储管理模拟实验剖析》由会员分享,可在线阅读,更多相关《操作系统实验4-请求分页存储管理模拟实验剖析(11页珍藏版)》请在金锄头文库上搜索。

1、实验四请求分页存储管理模拟实验一:实验目的通过对页面、页表、地址转换和页面置换过程的模拟,加深对请求分页存储管理系统的原理和实现技术的理解。二:实验内容假设每个页面可以存放10条指令,分配给进程的存储块数为4。用C语言或Pascal语言模拟一进程的执行过程。设该进程共有320条指令,地址空间为32个页面,运行前所有页面均没有调入内存。模拟运行时,如果所访问的指令已经在内存,则显示其物理地址,并转下一条指令;如果所访问的指令还未装入内存,则发生缺页,此时需要记录缺页产生次数,并将相应页面调入内存,如果4个内存块已满,则需要进行页面置换。最后显示其物理地址,并转下一条指令。在所有指令执行完毕后,显

2、示进程运行过程中的缺页次数和缺页率。页面置换算法:分别采用OPT、FIFO、LRU三种算法。进程中的指令访问次序按如下原则生成:50%的指令是顺序执行的。25%的指令是均匀分布在低地址部分。25%的指令是均匀分布在高地址部分。三:实验类别分页存储管理四:实验类型模拟实验五:主要仪器计算机六:结果OPT:LRU:FIFO:七:程序# include# include# include# define blocknum 4/页面尺寸大小int m; /程序计数器,用来记录按次序执行的指令对应的页号static int num320; /用来存储320条指令typedef struct BLOCK

3、/声明一种新类型-物理块类型 int pagenum; /页号int accessed; /访问量,其值表示多久未被访问BLOCK; BLOCK blockblocknum; /定义一大小为8的物理块数组void init() /程序初始化函数,对block初始化 for(int i=0;iblocknum;i+) blocki.pagenum=-1;blocki.accessed=0;m=0;int pageExist(int curpage)/查找物理块中页面是否存在,寻找该页面curpage是否在内存块block中,若在,返回块号for(int i=0; iblocknum; i+) i

4、f(blocki.pagenum = curpage )return i; /在内存块block中,返回块号return -1;int findSpace()/查找是否有空闲物理块,寻找空闲块block,返回其块号for(int i=0;iblocknum;i+) if(blocki.pagenum=-1)return i; /找到了空闲的block,返回块号 return -1;int findReplace()/查找应予置换的页面 int pos = 0;for(int i=0;i blockpos.accessed)pos = i; /找到应该置换页面,返回BLOCK中位置 return

5、 pos;void display()/显示物理块中的页面号 for(int i=0; iblocknum; i+) if(blocki.pagenum != -1)printf( %02d ,blocki.pagenum);printf(%p |,&blocki.pagenum);printf(n);void randam()/产生320条随机数,显示并存储到num320 int flag=0;printf(请为一进程输入起始执行指令的序号(0320):n);scanf(%d,&m);/用户决定的起始执行指令printf(*进程中指令访问次序如下:(由随机数产生)*n);for(int i=

6、0;i320;i+)/进程中的320条指令访问次序的生成numi=m;/当前执行的指令数,if(flag%2=0) m=+m%320;/顺序执行下一条指令if(flag=1) m=rand()%(m-1);/通过随机数,跳转到低地址部分0,m-1的一条指令处,设其序号为m1if(flag=3) m=m+1+(rand()%(320-(m+1);/通过随机数,跳转到高地址部分m1+2,319的一条指令处,设其序号为m2flag=+flag%4;printf( %03d,numi);/输出格式:3位数if(i+1)%10=0) /控制换行,每个页面可以存放10条指令,共32个页面printf(n)

7、; void pagestring() /显示调用的页面序列,求出此进程按次序执行的各指令所在的页面号并显示输出 for(int i=0;i320;i+)printf( %02d,numi/10);/输出格式:2位数if(i+1)%10=0)/控制换行,每个页面可以存放10条指令,共32个页面printf(n);void OPT() /最佳替换算法 int n=0;/记录缺页次数int exist,space,position;int curpage;/当前指令的页面号for(int i=0;i320;i+) m=numi; curpage=m/10;exist=pageExist(curpa

8、ge);if(exist=-1) /当前指令的页面号不在物理块中space=findSpace();if(space != -1) /当前存在空闲的物理块blockspace.pagenum = curpage; /将此页面调入内存display();/显示物理块中的页面号n+;/缺页次数+1else /当前不存在空闲的物理块,需要进行页面置换for(int k=0;kblocknum;k+)for(int j=i;j320;j+)/找到在最长(未来)时间内不再被访问的页面if(blockk.pagenum!= numj/10) blockk.accessed = 1000; /将来不会被访问

9、,设置为一个很大数else /将来会被访问,访问量设为jblockk.accessed = j;break; position = findReplace();/找到被置换的页面 ,淘汰blockposition.pagenum = curpage;/ 将新页面调入display();n+; /缺页次数+1printf(缺页次数:%dn,n);printf(缺页率:%f%n,(n/320.0)*100);void LRU() /最近最久未使用算法 int n=0;/记录缺页次数int exist,space,position ;int curpage;/当前指令的页面号for(int i=0;

10、i320;i+) m=numi; curpage=m/10;exist = pageExist(curpage);if(exist=-1) /当前指令的页面号不在物理块中space = findSpace();if(space != -1) /当前存在空闲的物理块blockspace.pagenum = curpage; /将此页面调入内存display();/显示物理块中的页面号n+;/缺页次数+1else /当前不存在空闲的物理块,需要进行页面置换position = findReplace(); blockposition.pagenum = curpage; display();n+;

11、 /缺页次数+1else blockexist.accessed = -1;/恢复存在的并刚访问过的BLOCK中页面accessed为-1for(int j=0; jblocknum; j+)/其余的accessed+blockj.accessed+;printf(缺页次数:%dn,n);printf(缺页率:%f%n,(n/320.0)*100);void FIFO() int n=0;/记录缺页次数 int exist,space,position ; int curpage;/当前指令的页面号 int blockpointer=-1; for(int i=0;i320;i+) m=num

12、i; curpage=m/10; exist = pageExist(curpage); if(exist=-1) /当前指令的页面号不在物理块中 space = findSpace(); if(space != -1) /当前存在空闲的物理块 blockpointer+; blockspace.pagenum=curpage; /将此页面调入内存 n+;/缺页次数+1 display();/显示物理块中的页面号 else / 没有空闲物理块,进行置换 position = (+blockpointer)%4; blockposition.pagenum = curpage; /将此页面调入内存 n+; display(); printf(缺页次数:%dn,n); printf(缺页率:%f%n,(n/320.0)*100);

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 高等教育 > 大学课件

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号