FIFO算法

package studyJava;
class FIFO{
/*
* 先进先出算法
* N:内存块的个数
* array:内存块
* size:页面数目
* */
private static final int N=3;
private int size;
Object[] array=new Object[N];
public boolean isEmpty(){
if(size==0)
return true;
else
return false;
}
//
public boolean isFully(){
if(size>=N)
return true;
else
return false;
}
/*
* 页面数目
* */
public int size(){
return size;
}
/*
* 查找元素O在数组array中的位置
* */
public int indexOfElement(Object o){
for(int i=0;i<N;i++){
if(array[i]==o)
return i;
}
return -1;//否则o不在array中
}
/*
* 页面转换
* */
public Object trans(Object o){
Object e=null;
int t=0;
if(indexOfElement(o)!=-1){
t=indexOfElement(o);
for (int i = t; i < size-1; i++) {
array[i]=array[i+1];
}
array[size-1]=o;
}else{
if(!isFully()){
array[size]=o;
size++;
}else{
for (int i = 0; i < size-1; i++) {
array[i]=array[i+1];
}
array[size-1]=o;
}
}
if(t==-1)
return null;
else
return array[t];
}
/*
* 输出内存块中的各数据
* */
public void showMemoryBlock(){
for (int i = 0; i < size; i++) {
System.out.print(array[i]+" ");
}
System.out.println();
}
}
public class Main{
public static void main(String[] args) {
Integer[] in={7,0,1,2,0,3,0,4,2,3,0,3,2,1,2,0,1,7,0,1};
FIFO fifo=new FIFO();
for(int i=0; i<in.length; i++) {
fifo.trans(in[i]);
fifo.showMemoryBlock();

}
}
}

时间: 2024-10-06 07:54:43

FIFO算法的相关文章

C语言实现FIFO算法与LRU算法

在操作系统中,当程序在运行过程中,若其所要访问的页面不再内存中而需要把他们调入内存,但内存已无空闲空间时,为了保证该进程能正常运行,系统必须从内存调出一页程序或数据送磁盘的兑换区中.但哪一个页面调出,须根据一定的算法确定.通常,把选择换出页面的算法称为页面置换算法(Page-Replacement Algorithms).置换算法的好坏将直接影响到系统的性能. 1) 先进先出(FIFO)页面置换算法 该算法总是淘汰最先进入内存的页面,即选择在内存中驻留时间最久的页面予以淘汰.该算法实现简单,只需

FIFO算法与LRU算法的C++实现

#include <bits/stdc++.h> using namespace std; /** * FIFO算法的实现:其实是可以采用双端队列,然后限制一下 * 双端队列的长度,根据我的限制应该是4.对于查询是否出现 * 在这个队列里面,我们可以采用一个数组标记是否有存在. * * 测试数据如下 16 4 0 1 2 4 3 4 5 1 2 5 1 2 3 4 5 6 * **/ struct FIFO{ int len, m;///长度, len - 总访问数; m - 分配的物理块数

操作系统 页面置换算法LRU和FIFO

LRU(Least Recently Used)最少使用页面置换算法,顾名思义,就是替换掉最少使用的页面. FIFO(first in first out,先进先出)页面置换算法,这是的最早出现的置换算法.该算法总是淘汰最先进入内存的页面,即选择在内存中驻留时间最长的页面给予淘汰. FIFO置换算法有这样一个奇怪现象:内存空间块数越多,缺页中断率可能相反的越高(缺页中断次数越高). LFU(Least Frequently Used)最近最少使用算法,它是基于“如果一个数据在最近一段时间内使用次

缓存算法(页面置换算法)-FIFO、LFU、LRU

转自:http://www.cnblogs.com/dolphin0520/ 1.FIFO算法 FIFO(First in First out),先进先出.其实在操作系统的设计理念中很多地方都利用到了先进先出的思想,比如作业调度(先来先服务),为什么这个原则在很多地方都会用到呢?因为这个原则简单.且符合人们的惯性思维,具备公平性,并且实现起来简单,直接使用数据结构中的队列即可实现. 在FIFO Cache设计中,核心原则就是:如果一个数据最先进入缓存中,则应该最早淘汰掉.也就是说,当缓存满的时候

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

暴力直接上代码,主要是用了vector来实现,有些方法比较费时,不太好,请各位大神斧正.这是个人的作业,  这是代码下载页http://download.csdn.net/detail/l631068264/7644569   里面还有多级反馈队列进程调度的MFC版 #include <iostream> #include <algorithm> #include <vector> #include <stdio.h> #include <stdlib

【转】缓存淘汰算法系列之3——FIFO类

原文地址:http://www.360doc.com/content/13/0805/16/13247663_304923435.shtml 1 FIFO 1.1. 原理 按照“先进先出(First In,First Out)”的原理淘汰数据. 1.2. 实现 FIFO队列,具体实现如下: 1. 新访问的数据插入FIFO队列尾部,数据在FIFO队列中顺序移动: 2. 淘汰FIFO队列头部的数据: 1.3. 分析 l 命中率 命中率很低,因为命中率太低,实际应用中基本上不会采用. l 复杂度 简单

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

目录 00 简介 01 算法概述 02 公用方法 03 先进先出置换算法(FIFO) 04 最近最久未使用(LRU)算法 05 最佳置换算法(OPT) 00 简介 页面置换算法主要是记录内存的忙闲状态,为进程分配和释放内存.当主存的空间太小而无法装入所有的进程时,就需要在内存和硬盘之间进行调度操作. 多数操作系统只采用某种特定的页面置换算法进行置换,无法预先探测当前运行进程的页面访问模式,因此不能根据不同的页面访问模式,选用不同的页面置换算法.当然,如果能对不同的访问模式选取相应的页面置换算法,

虚存管理页面置换算法 — FIFO和RUL算法模拟实现

本篇博文为追忆曾经写过的算法系列第一篇(20081021) 温故知新 目的: 为了解决内存容量有限与多作业运行的冲突,运用了虚拟存储技术,能从逻辑上对内存进行扩充,达到扩充内存的效果.分页存储管理是实现虚拟存储的一种方案.通过模拟算法的实验,加深理解,虚拟存储器的基本原理和方法. 要求: 1.请求分页的置换算法(FIFO && RUL算法实现):2.按给定的顺序列,输出页面调度过程包括命中 / 缺页,调入/调出:3.计算缺页率,频率. 说明: vp_list[N] //访问序列 bs[M]

FIFO调用算法(不完整版)

#include<stdio.h>#include<iostream.h>#include <stdlib.h>#include<time.h>#define Stack_size 4 struct aa{ //代表一个物理页的节点int page; //物理页存放的虚存页号aa* next; //指向下一物理页};typedef struct{int elem[Stack_size];int top;int top2;}Seq; void Soseq(Se