操作系统页面置换算法之先进先出(FIFO)算法

操作系统页面置换算法之先进先出(FIFO)算法

在操作系统页面置换算法中,最简单的页面置换算法为FIFO算法。FIFO页面置换算法为每个页记录着该页调入内存的时间。当必须置换一页时,将选择最旧的页。注意不需要记录调入一页的确切时间。可以创建一个FIFO队列来管理内存中的所有页。队列中的首页将被置换。当需要调入页时,将它加到队列的尾部。下面将以Java语言模拟FIFO算法,其中,帧的数量为5,引用串中页号不包含0。

import java.util.LinkedList;
import java.util.List;

public class FIFO {
public static void main(String[] args) {
int framesize = 5;   //帧数量
int[] s = { 1, 2, 3, 4, 2, 1, 5, 6, 2, 1, 2, 3, 7, 6, 3, 2, 1, 2, 3, 6 }; //引用串
int[] is = new int[s.length];
for (int i = 0; i < s.length; i++)
is[i] = 0;
int aa[][] = new int[s.length][framesize];
List<Integer> q = new LinkedList<Integer>();
int count = 0;
for (int i = 0; i < framesize; i++)
q.add(0);
for (int i = 0; i < s.length; i++) {
if (!q.contains(new Integer(s[i]))) {
q.remove(0);
q.add(new Integer(s[i]));
count++;
is[i] = 1;
}
int j = 0;
for (Integer v : q)
aa[i][j++] = v;
}
for (int i = 0; i < framesize; i++) {
for (int j = 0; j < s.length; j++) {
System.out.print(aa[j][i] + " ");
}
System.out.println();
}
System.out.println();
for (int i = 0; i < s.length; i++) {
System.out.print(is[i] + " ");
}
System.out.println();
System.out.println("total : " + count);
}
}

执行结果如下:

0 0 0 0 0 0 1 2 2 3 4 5 6 6 6 6 6 6 6 6 
0 0 0 1 1 1 2 3 3 4 5 6 1 1 1 1 1 1 1 1 
0 0 1 2 2 2 3 4 4 5 6 1 2 2 2 2 2 2 2 2 
0 1 2 3 3 3 4 5 5 6 1 2 3 3 3 3 3 3 3 3 
1 2 3 4 4 4 5 6 6 1 2 3 7 7 7 7 7 7 7 7 
============================
1 1 1 1 0 0 1 1 0 1 1 1 1 0 0 0 0 0 0 0 
total : 10

其中,等号上方每一列表示队列,0表示空闲帧,等号下方1代表发生页面置换,0表示未发生页面置换。

  • 5
    点赞
  • 28
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值