虚存管理页面置换算法 — FIFO和RUL算法模拟实现
本篇博文为追忆以前写过的算法系列第一篇(20081021)
温故知新
目的: 为了解决内存容量有限与多作业执行的冲突。运用了虚拟存储技术。能从逻辑上对内存进行扩充,达到扩充内存的效果。分页存储管理是实现虚拟存储的一种方案。通过模拟算法的实验。加深理解,虚拟存储器的基本原理和方法。
要求: 1.请求分页的置换算法(FIFO
&& RUL算法实现);2.按给定的顺序列,输出页面调度过程包含命中
/ 缺页,调入/调出;3.计算缺页率,频率。
说明:
vp_list[N] //訪问序列
bs[M] //内存块表,M为内存块大小
struct pt{
int pno; //页号
int bno; //块号
int flag; //状态位,为0时在不内存。为1时在内存
int order; //优先序号
};
算法流程:
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvZ3VqaW5qaW5zZXU=/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast" />
程序:
/* gujinjin 08/10/20 */
/* 程序名称:fifo &&LRU */
/* 程序目的:页面置换算法的FIFO编程实现 */
#include<iostream>
using namespace std;
#define N 20 //訪问序列数组大小
#define M 10 //内存块表数组大小
struct pt{
int pno; //页号
int bno; //块号
int flag; //状态位,为0时在不内存,为1时在内存
int order; //优先序列
};
/*------------------------------------------*/
/*输入函数*/
/*------------------------------------------*/
void input(int *a,int n)
{
for(int i=0;i<n;i++){cin>>*a;a++;}
}
/*------------------------------------------*/
/*输出函数*/
/*------------------------------------------*/
void output(int *a,int n)
{
for(int i=0;i<n;i++){cout<<*a<<'\t';a++;}
cout<<'\n';
}
/*------------------------------------------*/
/*算法fifo && LRU函数*/
/*------------------------------------------*/
void fifo(int*vp_list,int*bs,int n,int m)
{
pt ptlist[N];//定义结构数组
int k=0,flag,cn=0,i,j;//cn——统计缺页数
for(j=0;j<m;j++)//赋初值
{
bs[j]=0;
}
for(i=0;i<n;i++)// 訪问序列循环
{
flag=0;
for(j=0;j<m;j++)
if(vp_list[i]==bs[j]){flag=1;break;}
if(flag==1)//命中
{
ptlist[i].bno =j+1;
ptlist[i].flag =1;
ptlist[i].pno =vp_list[i];
}
else{
ptlist[i].flag =0;
ptlist[i].pno =vp_list[i];
bs[k]=vp_list[i];
ptlist[i].bno =k+1;
k=(k+1)%m;//取模——循环队列
cn++;
}
}
cout<<"FIFO算法:\n";
cout<<"----------------------------------**\n";
cout<<"缺页率为:"<<'\t'<<(float)cn/n<<'\n';
cout<<"-------------------------------------------------------------------**\n";
cout<<"序列号\n";
cout<<"-------------------------------------------------------------------**\n";
for(i=0;i<m;i++)
{
cout<<vp_list[i]<<"\t缺页!\t"<<"直接存入内存块!\n";
cout<<"-------------------------------------------------------------------**\n";
}
for(i=m;i<n;i++)
{
if(ptlist[i].flag ==0)
cout<<vp_list[i]<<"\t缺页!\t"<<"调出------块号为"<<ptlist[i].bno <<"--页号为"<<ptlist[i].pno <<'\n';
else cout<<vp_list[i]<<"\t命中!"<<"\t位置------块号为"<<ptlist[i].bno <<"--页号为"<<ptlist[i].pno <<'\n';;
cout<<"-------------------------------------------------------------------**\n";
}
}
void LRU(int*vp_list,int*bs,int n,int m)
{
//----------------------------------------------------------------------------------------------**
pt ptlist_LRU[N];
int k=0,flag,cn=0,i,j;//cn——统计缺页数
int com;
for(j=0;j<m;j++)//赋初值
{
bs[j]=0;
}
for(j=0;j<n;j++)ptlist_LRU[j].order =0;
for(i=0;i<n;i++)// 訪问序列循环
{
flag=0;
for(j=0;j<m;j++)
if(vp_list[i]==bs[j]){flag=1;break;}
if(flag==1)//命中
{
ptlist_LRU[i].bno =j+1;
ptlist_LRU[i].flag =1;
ptlist_LRU[i].pno =vp_list[i];
ptlist_LRU[i].order--;
com=ptlist_LRU[i].order;
for(j=0;j<m;j++)
if(ptlist_LRU[j].order <com)
{com=ptlist_LRU[j].order;k=ptlist_LRU[j].bno ;}
}
else{
ptlist_LRU[i].flag =0;
ptlist_LRU[i].pno =vp_list[i];
bs[k]=vp_list[i];
ptlist_LRU[i].bno =k+1;
if(i<m)k=(k+1)%m;
cn++;
}
}
cout<<"LRU*算法:\n";
cout<<"----------------------------------**\n";
cout<<"缺页率为:"<<'\t'<<(float)cn/n<<'\n';
cout<<"-------------------------------------------------------------------**\n";
cout<<"序列号\n";
cout<<"-------------------------------------------------------------------**\n";
for(i=0;i<m;i++)
{
cout<<vp_list[i]<<"\t缺页!\t"<<"直接存入内存块!\n";
cout<<"-------------------------------------------------------------------**\n";
}
for(i=m;i<n;i++)
{
if(ptlist_LRU[i].flag ==0)
cout<<vp_list[i]<<"\t缺页!\t"<<"调出------块号为"<<ptlist_LRU[i].bno <<"--页号为"<<ptlist_LRU[i].pno <<'\n';
else cout<<vp_list[i]<<"\t命中!"<<"\t位置------块号为"<<ptlist_LRU[i].bno <<"--页号为"<<ptlist_LRU[i].pno <<'\n';;
cout<<"-------------------------------------------------------------------**\n";
}
}
/*------------------------------------------*/
/*主函数*/
/*------------------------------------------*/
void main()
{
int vp_list[N],bs[M];//定义訪问序列数组和内存块表数组
int n,m,choose;
cout<<"输入序列个数:\n";
cin>>n;
cout<<"输入内存块大小:\n";
cin>>m;
cout<<"请输入訪问序列:\n";
input(vp_list,n);
cout<<"选FIFO算法输入1,选LRU*算法输入2:";
cin>>choose;
cout<<"訪问序列:"<<endl;
output(vp_list,n);
cout<<"**----------------------------------------**";
cout<<'\n';
if(choose==1)
fifo(vp_list,bs,n,m);//调用fifo函数
if(choose==2)
LRU(vp_list,bs,n,m);
}
结果演示:
虚存管理页面置换算法 — FIFO和RUL算法模拟实现的更多相关文章
- c模拟 页式管理页面置换算法之FIFO
写的操作系统作业.... 放上来给需要的小伙伴 需要注意的地方: 1.该算法只涉及单进程 2.只是用c模拟FIFO的思想 FIFO思想:选择在内存中存活时间最久的页面淘汰 关于该算法我的理解: 一个进 ...
- 页面置换算 - FIFO、LFU、LRU
缓存算法(页面置换算法)-FIFO.LFU.LRU 在前一篇文章中通过leetcode的一道题目了解了LRU算法的具体设计思路,下面继续来探讨一下另外两种常见的Cache算法:FIFO.LFU 1 ...
- vmstat---有关进程、虚存、页面交换空间及 CPU信息
虚拟内存运行原理 在系统中运行的每个进程都需要使用到内存,但不是每个进程都需要每时每刻使用系统分配的内存空间.当系统运行所需内存超过实际的物理内存,内核会释放某些进程所占用但未使用的部分或所有物理内存 ...
- Linux 虚存的性能问题
虚存子系统是所有 UNIX 系统的核心组件.下面讨论虚存系统的实现及其对操作系统中几乎其他所有子系统的作用和影响.首先详细说明一些基本的内存管理问题:然后具体分析 Linux 操作系统如何实施虚存管理 ...
- 先进先出算法(FIFO)——页面置换
原创 最近操作系统实习,写了先进先出算法(FIFO)的代码来实现页面置换. 题目阐述如下: 设计四:页面置换 设计目的: 加深对请求页式存储管理实现原理的理解,掌握页面置换算法. 设计内容: 设计一个 ...
- (待续)C#语言中的动态数组(ArrayList)模拟常用页面置换算法(FIFO、LRU、Optimal)
目录 00 简介 01 算法概述 02 公用方法与变量解释 03 先进先出置换算法(FIFO) 04 最近最久未使用(LRU)算法 05 最佳置换算法(OPT) 00 简介 页面置换算法主要是记录内存 ...
- 页面置换算法 - FIFO、LFU、LRU
缓存算法(页面置换算法)-FIFO. LFU. LRU 在前一篇文章中通过leetcode的一道题目了解了LRU算法的具体设计思路,下面继续来探讨一下另外两种常见的Cache算法:FIFO. LFU ...
- 操作系统的页面置换C++算法:OPT FIFO LRU CLOCK 计算缺页率
暴力直接上代码,主要是用了vector来实现,有些方法比較费时,不太好,请各位大神斧正.这是个人的作业, 这是代码下载页http://download.csdn.net/detail/l631068 ...
- 操作系统页面置换算法(opt,lru,fifo,clock)实现
选择调出页面的算法就称为页面置换算法.好的页面置换算法应有较低的页面更换频率,也就是说,应将以后不会再访问或者以后较长时间内不会再访问的页面先调出. 常见的置换算法有以下四种(以下来自操作系统课本). ...
随机推荐
- 为什么V8引擎这么快?[转]
转载请注明出处:http://blog.csdn.net/horkychen Google研发的V8 JavaScript引擎性能优异.我们请熟悉内部程序实现的作者依源代码来看看V8是如何加速的. 作 ...
- Linux权限详解 命令之 chmod:修改权限
权限简介 Linux系统上对文件的权限有着严格的控制,用于如果相对某个文件执行某种操作,必须具有对应的权限方可执行成功. Linux下文件的权限类型一般包括读,写,执行.对应字母为 r.w.x. Li ...
- actor 内最好不要阻塞
1. 在使用 akka cluster singleton 时,我需要知道被创建的 singleton proxy 的 actorRef,通过绝对路径加 actorSelection 方法,应该很容易 ...
- [原]jenkins(六)---jenkins远程部署脚本
/** * lihaibo * 文章内容都是根据自己工作情况实践得出. * 版权声明:本博客欢迎转发,但请保留原作者信息! http://www.cnblogs.com/horizonli/p/533 ...
- 错误票据|2013年蓝桥杯B组题解析第七题-fishers
错误票据 某涉密单位下发了某种票据,并要在年终全部收回. 因为工作人员疏忽,在录入ID号的时候发生了一处错误,造成了某个ID断号,另外一个ID重号. 你的任务是通过编程,找出断号的ID和重号的ID. ...
- maven安装与创建多模块项目
最新版已同步至 http://yywang.info/2014/05/31/maven-install-and-create-project/ maven是一个比较流行的项目管理工具,在最近参与的项目 ...
- EF中的预先加载和延迟加载
延迟加载(Lazy Loading):当实体第一次被读取时,相关数据不会被获取,只会读取本身.延迟加载的数据不会一次性查出来,而是一条一条的查询,这样就会多次请求数据库进行查询. 预先加载<Ea ...
- Selenium模拟浏览器抓取淘宝美食信息
前言: 无意中在网上发现了静觅大神(崔老师),又无意中发现自己硬盘里有静觅大神录制的视频,于是乎看了其中一个,可以说是非常牛逼了,让我这个用urllib,requests用了那么久的小白,体会到sel ...
- [No0000F7]C# 多态性
多态性意味着有多重形式.在面向对象编程范式中,多态性往往表现为"一个接口,多个功能". 多态性可以是静态的或动态的.在静态多态性中,函数的响应是在编译时发生的.在动态多态性中,函数 ...
- tensorflow如何正确加载预训练词向量
使用预训练词向量和随机初始化词向量的差异还是挺大的,现在说一说我使用预训练词向量的流程. 一.构建本语料的词汇表,作为我的基础词汇 二.遍历该词汇表,从预训练词向量中提取出该词对应的词向量 三.初始化 ...