亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

java中是如何實現頁面置換算法的

發布時間:2020-08-10 09:17:10 來源:億速云 閱讀:147 作者:小新 欄目:開發技術

這篇文章給大家分享的是有關java中是如何實現頁面置換算法的的內容。小編覺得挺實用的,因此分享給大家做個參考。一起跟隨小編過來看看吧。

原理就不說了,直接上代碼

FIFO

import java.util.ArrayList;
import java.util.List;

import utils.ListUtils;


/**
 * 
 * 
 * @author cnkeysky
 *
 */

public class FIFO {

 public void run() {
 String[] inputStr = {"1", "2", "3", "4", "2", "1", "2", "3", "5", "2", "3", "7", "6"};
 // 內存塊
 int memory = 3;
 List<String> list = new ArrayList<>();
 for(int i = 0; i < inputStr.length; i++){
  if(i == 0){
  list.add(inputStr[i]);
  System.out.println("第"+ i +"次訪問:\t\t" + ListUtils.listToString(list));
  }else {
  if(ListUtils.find(list, inputStr[i])){
   System.out.println("第" + i + "次" + "訪問:\t\t" + ListUtils.listToString(list));
  }else{
   if(list.size() < memory){
   list.add(inputStr[i]);
   }else{
   list.remove(0);
   list.add(inputStr[i]);

   }
   System.out.println("第" + i + "次" + "訪問:\t\t" + ListUtils.listToString(list));
  }
  }
 }
 }

}

LRU

import utils.ListUtils;

import java.util.ArrayList;
import java.util.List;

/**
 * 最近最久未用置換算法
 * @author cnkeysky
 *
 */

public class LRU {

 public static void main(String[] args) {
 String[] inputStr = {"6", "7", "6", "5", "9", "6", "8", "9", "7", "6", "9", "6"};
 // 內存塊
 int memory = 3;
 List<String> list = new ArrayList<>();
 for(int i = 0; i < inputStr.length; i++){
  if(i == 0){
  list.add(inputStr[i]);
  System.out.println("第"+ i +"次訪問:\t\t" + ListUtils.listToString(list));
  }else {
  if(ListUtils.find(list, inputStr[i])){
   // 存在字符串,則獲取該下標
   int index = ListUtils.findIndex(list, inputStr[i]);
   // 下標不位于棧頂時,且list大小不為1時
   if(!(list.get(list.size() - 1)).equals(inputStr[i]) && list.size() != 1) {
   String str = list.get(index);
   list.remove(index);
   list.add(str);
   }
   System.out.println("第" + i + "次" + "訪問:\t\t" + ListUtils.listToString(list));
  }else{
   if(list.size()>= memory) {
   list.remove(0);
   list.add(inputStr[i]);
   System.out.println("第" + i + "次" + "訪問:\t\t" + ListUtils.listToString(list));
   }else {
   list.add(inputStr[i]);
   System.out.println("第" + i + "次" + "訪問:\t\t" + ListUtils.listToString(list));
   }
  }
  }
 }
 }
}

Clock

import java.util.ArrayList;
import java.util.List;

import utils.ListUtils;

/**
 * 
 * 
 * @author cnkeysky
 *
 */
public class Clock {

 public static void main(String[] args) {
 String[] inputStr = {"6", "7", "6", "5", "9", "6", "8", "9", "7", "6", "9", "6"};
 List<String> list = new ArrayList<>();
 // 內存塊
 int memory = 3;
 // 缺頁次數
 int count = 0;
 String[] clock = new String[memory];
 int indexNext = 0;
 int index = 0;
 // 初始化時鐘
 for(int i = 0; i < memory; i++) {
  clock[i] = "0";
 }
 for(int i = 0; i < inputStr.length; i++) {
  int indexPre = 0;
  if (i == 0) {
  list.add(inputStr[i]);
  clock[indexNext] = "1";
  indexNext++;
  System.out.println("第"+ i +"次訪問:\t\t" + ListUtils.listToString(list));
  }else {

  if(ListUtils.find(list, inputStr[i])) {
   indexPre = ListUtils.findIndex(list, inputStr[i]);
   if(clock[indexPre].equals("0")) {
   clock[indexPre] = "1";
   }
   count++;
   System.out.println("第"+ i +"次訪問:\t\t" + ListUtils.listToString(list));
  }else {
   if(list.size() < memory) {
   list.add(inputStr[i]);
   clock[indexNext] = "1";
   indexNext++;
   System.out.println("第"+ i +"次訪問:\t\t" + ListUtils.listToString(list));
   }else {
   index = ListUtils.findZero(indexNext, clock, memory);
   list.remove(index);
   list.add(index, inputStr[i]);
   clock[index] = "1";
   indexNext = index + 1;
   System.out.println("第"+ i +"次訪問:\t\t" + ListUtils.listToString(list));
   }
  }
  }
  if(indexNext > memory - 1) {
  indexNext = Math.abs(memory - indexNext);
  }
 }
 System.out.println("缺頁次數:" + (inputStr.length-count));
 }

}

工具類ListUtils

import java.util.List;

public class ListUtils {

 public ListUtils() {

 }

 /**
 * 輸出
 * @param list 將List轉為數組并輸出, out: 2, 3, 4 
 * @return
 */
 public static String listToString(List list){

 StringBuffer content = new StringBuffer();
 for(int i = 0; i < list.size(); i++){
  content.append(list.get(i));
  if(i < list.size() - 1){
  content.append(",");
  }
 }
 return content.toString();
 }

 /**
 * 在list中查找是否有str
 * @param list
 * @param str
 * @return
 */
 public static boolean find(List<String> list, String str){
 boolean flag = false;
 for(String lis : list){
  if(lis.equals(str)){
  flag = true;
  }
 }
 return flag;
 }

 /**
 * 在List中查找是否有String,如果有返回下標, 否則返回 -1
 * @param list
 * @param str
 * @return
 */
 public static int findIndex(List<String> list, String str) {

 int index = 0;
 for(String lis : list) {
  if(lis.equals(str)) {
  return index;
  }
  index++;
 }
 return -1;
 }

 public static boolean clockJudge(String[] clock, int index) {
 if(clock[index].equals("0")) {
  return true;
 }
 return false;
 }
 /**
 * 
 * @param index 下標
 * @param clock 時鐘
 * @param range 當前使用內存塊
 * @return
 */
 public static int findZero(int index, String[] clock, int range) {

 while(true) {

  if(clock[index].equals("0")) {
  break;
  }else {
  clock[index] = "0";
  index++;
  if(index > range-1) {
   index = Math.abs(range - index);
  }
  }
 }
 return index;
 }

 /**
 * 在數組中查找是否存在該字符串
 * @param obj
 * @param str
 * @return
 */
 public static boolean strJudge(Object[] obj, String str) {
 boolean flag = false;
 if(obj == null) {
  return flag;
 }
 for(int i = 0; i < obj.length; i++) {
  if(str.equals(obj[i])) {
  flag = true;
  break;
  }
 }
 return flag;
 }

 /**
 * 獲取二維數組中同一列的行的長度
 * @param str 數據
 * @param length 二維數組的列
 * @param memory 內存塊
 * @return
 * 
 */

 public static int findNull(Object[][] str, int length, int memory) {

 int index = 0;
 if(str == null) {
  return -1;
 }
 for(int i = 0; i < memory; i++) {
  if(str[i][length] != null) {
  index = i;
  }
 }
 return index;
 }
}

感謝各位的閱讀!關于java中是如何實現頁面置換算法的就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

体育| 奉化市| 衢州市| 肃北| 通山县| 永嘉县| 金湖县| 嘉峪关市| 夹江县| 炉霍县| 元朗区| 松溪县| 石楼县| 佛冈县| 诏安县| 宁安市| 凤阳县| 海原县| 中山市| 望都县| 扬中市| 三原县| 汪清县| 通山县| 延津县| 板桥市| 泰兴市| 扎鲁特旗| 兴海县| 怀安县| 博客| 色达县| 大新县| 宁化县| 巴中市| 余江县| 太仆寺旗| 囊谦县| 宜良县| 鄂托克旗| 普兰县|