已阅读5页,还剩1页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
实 验 报 告课程名称操作系统实验班级实验日期姓 名学号实验成绩实验名称存储器管理实验目的及要求1、编程模拟实现存储器页面置换的常用算法,调试分析相关存储器管理程序,加深对存储器页面置换常用算法的理解和实现技巧实验内容1、 自定义存储器管理有关的数据结构;2、 依据最佳置换算法(OPTIMAL)、先进先出置换算法(FIFO)、最近最久未使用算法(LRU)原理,编写对应函数,模拟系统的存储器页面置换功能;3、 为了更好地模拟和评价算法的性能,允许用户自行指定可用页块数并输入需访问的页面号序列;4、 统计以上算法实际需要的总页面数、缺页中断次数以及它们的缺页率;5、 比较/分析以上算法的置换性能,并作出自己的评价。算法描述及实验步骤1、 数据结构、自定义宏、全局变量#includeusing namespace std;struct Page int num; /页面号 int timer; /计时; 2、 函数声明class pagepropublic: pagepro(); int Bsize; /进程页块数 int Psize; /访问序列长度 int findspace(); /若内存块中有空,返回该位置 int findhave(int p); /若内存块中已有页,返回内存块中位置 int findreplace(); /找到替换页的位置(for LRU) int findreplace(int i); /找到替换页的位置(for OPT) void clear(); /清理内存块 void display(); /打印内存块信息 int LRU(); /最近最久未使用算法 int FIFO(); /先进先出算法 int OPT(); /最佳置换算法 Page *block; /内存块 Page *page; /页面号串;调试过程及实验结果1、 最近最久未使用算法(LRU)2、 使用先进先出置换算法(FIFO)3、 使用最佳置换算法(OPT)附录源代码:#includeusing namespace std;struct Page int num; /页面号 int timer; /计时;class pagepropublic: pagepro(); int Bsize; /进程页块数 int Psize; /访问序列长度 int findspace(); /若内存块中有空,返回该位置 int findhave(int p); /若内存块中已有页,返回内存块中位置 int findreplace(); /找到替换页的位置(for LRU) int findreplace(int i); /找到替换页的位置(for OPT) void clear(); /清理内存块 void display(); /打印内存块信息 int LRU(); /最近最久未使用算法 int FIFO(); /先进先出算法 int OPT(); /最佳置换算法 Page *block; /内存块 Page *page; /页面号串;pagepro:pagepro()int pstr100;cout请输入各页面数:Psize;cout输入各页号:endl;for(int j=0;jpstrj;cout输入物理块数:Bsize; int i=0; block=new PageBsize; for(i=0;iBsize;i+) blocki.num=-1; blocki.timer=0; page=new PagePsize; for(i=0;iPsize;i+) pagei.num=pstri; pagei.timer=0; int pagepro:findspace() for(int i=0;iBsize;i+) if(blocki.num=-1) return i; return -1;int pagepro:findreplace(int i) int pos3=0; int postion=0; for(int j=0;jBsize;j+) for(int k=i;kPsize;k+) if(blockj.num=pagek.num) break; else posj+; for(j=1;j pospostion) postion=j; return postion;int pagepro:findhave(int p) for(int i=0;iBsize;i+) if(blocki.num=pagep.num) return i; return -1;void pagepro:display() for(int i=0;iBsize;i+) if(blocki.num !=-1) coutblocki.num ; coutendl;int pagepro:findreplace() int pos=0; for(int i=1;i blockpos.timer) pos = i; return pos;void pagepro:clear() for(int i=0;iBsize;i+) blocki.num=-1; blocki.timer=0; int pagepro:LRU() int have,space,pos; int count=0; /不缺页计数 for(int i=0;iPsize;i+) have=findhave(i); if(have != -1) count+; blockhave.timer=-1; coutpage find in block!endl; else space=findspace(); if(space != -1) blockspace=pagei; display(); else pos=findreplace(); blockpos=pagei; display(); for(int i=0;iBsize;i+) blocki.timer+; return count;int pagepro:FIFO() int have; int j=0; /j%3 记录替换位置 int count=0; for(int i=0;iPsize;i+) have=findhave(i); if(have!=-1) count+; coutpage find in block!endl; else blockj%3=pagei; j+; display(); return count;int pagepro:OPT() int have,space; int count=0; for(int i=0;iPsize;i+) have=findhave(i); if(have!=-1) coutpage find in block!endl; count+; else space=findspace(); if(space!=-1) blockspace=pagei; display(); else blockfindreplace(i)=pagei; display(); return count;int main() int c=0, select=0; cout*页面置换算法模拟*endl; cout 1.最近最久未使用算法(LRU) endl; cout 2.使用先进先出置换算法(FIFO)endl; cout 3.使用最佳置换算法(OPT) endl; cout 0.退出endl; cout*endl; pagepro p1; coutselect; switch(select) case 1: c=p1.LRU(); couttotal:p1.Psizenfind:cendl; cout缺页率为(double)c*0.1/p1.Bsizeendl; p1.clear(); break; case 2: c=p1.FIFO(); couttotal:p1.Psizenfind:cendl; cout缺页率为(double)c*0.1/p1.Bsizeendl; p1.clear(); break; case 3: c=p1.OPT(); couttotal:p1.Psizenfin
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2024年大庆辅警招聘考试题库及答案详解(有一套)
- 2024年大足县辅警协警招聘考试真题含答案详解(模拟题)
- 2023年赣州辅警协警招聘考试真题完整参考答案详解
- 2024年城口县辅警协警招聘考试真题附答案详解(综合卷)
- 2023年阿克苏辅警协警招聘考试备考题库附答案详解(研优卷)
- 2023年黑龙江辅警招聘考试真题及答案详解(名师系列)
- 2023年铜陵辅警协警招聘考试备考题库及答案详解(典优)
- 2024年双鸭山辅警协警招聘考试备考题库及完整答案详解一套
- 2024年佳木斯辅警招聘考试真题及答案详解(夺冠系列)
- 2023年防城港辅警招聘考试题库及答案详解(名师系列)
- 初级应急救援员理论考试复习题及答案
- 货梯安全培训内容
- 广东离婚协议书范文2024标准版
- 专业技术人员能力水平评价表2023版
- 高等学校英语应用能力B级讲解省公开课一等奖全国示范课微课金奖课件
- JTGT F20-2015 公路路面基层施工技术细则
- 中枢神经系统监测课件
- 神经病理性疼痛的药物治疗
- 侨界领袖陈嘉庚(共33张PPT)
- 职业病危害因素分类目录与职业禁忌症以及职业病目录对应表
- 《建筑结构平法识图》说课
评论
0/150
提交评论