本篇博文为追忆以前写过的算法系列第一篇(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. 【12月26日】A股滚动市盈率PE最低排名

    深康佳A(SZ000016) - 滚动市盈率PE:1.47 - 滚动市净率PB:0.98 - 滚动年化股息收益率:4.97% - 消费电子产品 - 深康佳A(SZ000016)的历史市盈率走势图 华菱 ...

  2. duilib进阶教程 -- 在duilib中使用MFC (2)

    好人做到底,送佛送到西.虽然上一篇教程已经说得很详细了,但Alberl还是再举一个例子.上一篇教程的主窗口是MFC的,所以这篇教程把主窗口换成duilib的~O(∩_∩)O~ 1.我们利用<20 ...

  3. [Bayes] runif: Inversion Sampling

    runifum Inversion Sampling 看样子就是个路人甲. Ref: [Bayes] Hist & line: Reject Sampling and Importance S ...

  4. MFC接收命令行参数的三种方法

    方法一: CString sCmdline = ::GetCommandLine(); AfxMessageBox(sCmdline); 将获取到 "C:\test\app.exe -1 - ...

  5. case when then end

    当 a>b获取a,否则获取b,当a>c获取a,否则获取c,b大于c获取b否则获取c SELECT id,(CASE  WHEN a>b THEN a WHEN  a>c THE ...

  6. python 中面向对象的概念

    原文 域和作用空间 本地域,函数域(nonlocal)和 全局域(global) def scope_test(): def do_local(): spam = "local spam&q ...

  7. 查找C++代码中某一范围内的内存泄露

    #include <string.h> #define _CRTDBG_MAP_ALLOC #include <crtdbg.h> int _tmain(int argc, _ ...

  8. WPF使用Canvas绘制可变矩形

    1.问题以及解决办法 最近因为项目需要,需要实现一个位置校对的功能,大致的需求如下:有一个图片,有一些位置信息,但是位置信息可能和实际有些偏差,需要做简单调整,后面会对这张图片进行切割等,做些处理.( ...

  9. java封装实现Excel建表读写操作

    对 Excel 进行读写操作是生产环境下常见的业务,网上搜索的实现方式都是基于POI和JXL第三方框架,但都不是很全面.小编由于这两天刚好需要用到,于是就参考手写了一个封装操作工具,基本涵盖了Exce ...

  10. IBM flex system P260

    CMM 机箱管理模块 提供如下功能: 电力控制 风扇管理 机箱和计算节点初始化 交换机管理 诊断:机箱.IO选项和计算节点 资源发现和库存管理 资源告警和监控 机箱和计算节点的电源管理 安全策略管理 ...