本篇博文为追忆以前写过的算法系列第一篇(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算法模拟实现的更多相关文章

  1. c模拟 页式管理页面置换算法之FIFO

    写的操作系统作业.... 放上来给需要的小伙伴 需要注意的地方: 1.该算法只涉及单进程 2.只是用c模拟FIFO的思想 FIFO思想:选择在内存中存活时间最久的页面淘汰 关于该算法我的理解: 一个进 ...

  2. 页面置换算 - FIFO、LFU、LRU

      缓存算法(页面置换算法)-FIFO.LFU.LRU 在前一篇文章中通过leetcode的一道题目了解了LRU算法的具体设计思路,下面继续来探讨一下另外两种常见的Cache算法:FIFO.LFU 1 ...

  3. vmstat---有关进程、虚存、页面交换空间及 CPU信息

    虚拟内存运行原理 在系统中运行的每个进程都需要使用到内存,但不是每个进程都需要每时每刻使用系统分配的内存空间.当系统运行所需内存超过实际的物理内存,内核会释放某些进程所占用但未使用的部分或所有物理内存 ...

  4. Linux 虚存的性能问题

    虚存子系统是所有 UNIX 系统的核心组件.下面讨论虚存系统的实现及其对操作系统中几乎其他所有子系统的作用和影响.首先详细说明一些基本的内存管理问题:然后具体分析 Linux 操作系统如何实施虚存管理 ...

  5. 先进先出算法(FIFO)——页面置换

    原创 最近操作系统实习,写了先进先出算法(FIFO)的代码来实现页面置换. 题目阐述如下: 设计四:页面置换 设计目的: 加深对请求页式存储管理实现原理的理解,掌握页面置换算法. 设计内容: 设计一个 ...

  6. (待续)C#语言中的动态数组(ArrayList)模拟常用页面置换算法(FIFO、LRU、Optimal)

    目录 00 简介 01 算法概述 02 公用方法与变量解释 03 先进先出置换算法(FIFO) 04 最近最久未使用(LRU)算法 05 最佳置换算法(OPT) 00 简介 页面置换算法主要是记录内存 ...

  7. 页面置换算法 - FIFO、LFU、LRU

    缓存算法(页面置换算法)-FIFO. LFU. LRU 在前一篇文章中通过leetcode的一道题目了解了LRU算法的具体设计思路,下面继续来探讨一下另外两种常见的Cache算法:FIFO. LFU ...

  8. 操作系统的页面置换C++算法:OPT FIFO LRU CLOCK 计算缺页率

    暴力直接上代码,主要是用了vector来实现,有些方法比較费时,不太好,请各位大神斧正.这是个人的作业,  这是代码下载页http://download.csdn.net/detail/l631068 ...

  9. 操作系统页面置换算法(opt,lru,fifo,clock)实现

    选择调出页面的算法就称为页面置换算法.好的页面置换算法应有较低的页面更换频率,也就是说,应将以后不会再访问或者以后较长时间内不会再访问的页面先调出. 常见的置换算法有以下四种(以下来自操作系统课本). ...

随机推荐

  1. 【QT】error: 'SIGNAL' was not declared in this scope

    error: 'SIGNAL' was not declared in this scope  未在此范围内声明. connect(ui->Btnshowhello,SIGNAL(clicked ...

  2. 嵌入式Linux应用开发__求职要求

    A.熟悉嵌入式软件开发,有较好的C语言开发能力,熟悉Linux线程,信号量,同步,消息队列,网络编程,音频等:B.能够熟练使用GDB调试工具:C.熟悉linux脚本,对于Android编译环境有一定理 ...

  3. Python标准输出重定向

    目录 Python标准输出重定向 声明 一. 背景知识 二. 重定向方式 2.1 控制台重定向 2.2 print >>重定向 2.3 sys.stdout重定向 2.4 上下文管理器(C ...

  4. 【CF679D】Bear and Chase 最短路+乱搞

    [CF679D]Bear and Chase 题意:近日,鼠国的头号通缉犯,神出鬼没的怪盗——Joker正于摩登市出没!对于名侦探Jack来说,这正是将其捉拿归案的大号时机.形式化地,摩登市可以看成一 ...

  5. :eq

    匹配一个给定索引值的元素?只要在html页面每个元素都有索引值,相同的元素按html位置顺序从0开始往下排.给定索引值:给定一个html某个区域的元素的索引值,也是从0开始 不给区域就是从html从d ...

  6. asp.net 访问页面访问统计实现

    0x00.背景: 1.用户访问网站所有页面就将访问统计数加1 ,按每月存放. 2.站点并没有用到母版面来实现,所有各个页面都很独立. 3.网站是很早这前的网站,尽量省改动以前的代码.按理说我们应该做一 ...

  7. Ajax框架---dwr的用法

    通常使用Ajax时用的都是jQuery框架,现在公司的框架里用的都是dwr.我觉得dwr和jQuery中的ajax用法差不多,看起来也很像. 一.简介 百度百科上对dwr的描述: DWR采取了一个类似 ...

  8. PAT甲级1131 Subway Map【dfs】【输出方案】

    题目:https://pintia.cn/problem-sets/994805342720868352/problems/994805347523346432 题意: 告诉你一个地铁线路图,站点都是 ...

  9. TOP100summit【分享实录-网易】构建云直播分发网络

    本篇文章内容来自2016年TOP100summit网易视频云.网易杭州研究院服务端技术专家邵峰的案例分享.编辑:Cynthia 邵峰:网易视频云.网易杭州研究院服务端技术专家浙江大学计算机专业博士毕业 ...

  10. 如何查看目前正在使用的Windows10是哪个版本?

    其实相当的简单: win+R 输入winver,就会出现如下图的信息: 就能看到版本信息了