java實(shí)現(xiàn)頁(yè)面置換算法
本文實(shí)例為大家分享了java實(shí)現(xiàn)頁(yè)面置換算法的具體代碼,供大家參考,具體內(nèi)容如下
原理就不說(shuō)了,直接上代碼
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"}; // 內(nèi)存塊 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 +"次訪問(wèn):\t\t" + ListUtils.listToString(list)); }else { if(ListUtils.find(list, inputStr[i])){ System.out.println("第" + i + "次" + "訪問(wèn):\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 + "次" + "訪問(wèn):\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"}; // 內(nèi)存塊 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 +"次訪問(wèn):\t\t" + ListUtils.listToString(list)); }else { if(ListUtils.find(list, inputStr[i])){ // 存在字符串,則獲取該下標(biāo) int index = ListUtils.findIndex(list, inputStr[i]); // 下標(biāo)不位于棧頂時(shí),且list大小不為1時(shí) 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 + "次" + "訪問(wèn):\t\t" + ListUtils.listToString(list)); }else{ if(list.size()>= memory) { list.remove(0); list.add(inputStr[i]); System.out.println("第" + i + "次" + "訪問(wèn):\t\t" + ListUtils.listToString(list)); }else { list.add(inputStr[i]); System.out.println("第" + i + "次" + "訪問(wèn):\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<>(); // 內(nèi)存塊 int memory = 3; // 缺頁(yè)次數(shù) int count = 0; String[] clock = new String[memory]; int indexNext = 0; int index = 0; // 初始化時(shí)鐘 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 +"次訪問(wèn):\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 +"次訪問(wèn):\t\t" + ListUtils.listToString(list)); }else { if(list.size() < memory) { list.add(inputStr[i]); clock[indexNext] = "1"; indexNext++; System.out.println("第"+ i +"次訪問(wèn):\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 +"次訪問(wèn):\t\t" + ListUtils.listToString(list)); } } } if(indexNext > memory - 1) { indexNext = Math.abs(memory - indexNext); } } System.out.println("缺頁(yè)次數(shù):" + (inputStr.length-count)); } }
工具類ListUtils
import java.util.List; public class ListUtils { public ListUtils() { } /** * 輸出 * @param list 將List轉(zhuǎn)為數(shù)組并輸出, 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,如果有返回下標(biāo), 否則返回 -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 下標(biāo) * @param clock 時(shí)鐘 * @param range 當(dāng)前使用內(nèi)存塊 * @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; } /** * 在數(shù)組中查找是否存在該字符串 * @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; } /** * 獲取二維數(shù)組中同一列的行的長(zhǎng)度 * @param str 數(shù)據(jù) * @param length 二維數(shù)組的列 * @param memory 內(nèi)存塊 * @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; } }
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Java實(shí)現(xiàn)雙向鏈表(兩個(gè)版本)
這篇文章主要介紹了Java實(shí)現(xiàn)雙向鏈表(兩個(gè)版本)的相關(guān)資料,需要的朋友可以參考下2016-02-02MVC頁(yè)面之間參數(shù)傳遞實(shí)現(xiàn)過(guò)程圖解
這篇文章主要介紹了MVC頁(yè)面之間參數(shù)傳遞實(shí)現(xiàn)過(guò)程圖解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-11-11springMVC4之強(qiáng)大類型轉(zhuǎn)換器實(shí)例解析
本篇文章主要介紹了springMVC4之強(qiáng)大類型轉(zhuǎn)換器實(shí)例解析,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-04-04使用nacos實(shí)現(xiàn)自定義文本配置的實(shí)時(shí)刷新
我們都知道,使用Nacos時(shí),如果將Bean使用@RefreshScope標(biāo)注之后,這個(gè)Bean中的配置就會(huì)做到實(shí)時(shí)刷新,本文給大家介紹了如何使用nacos實(shí)現(xiàn)自定義文本配置的實(shí)時(shí)刷新,需要的朋友可以參考下2024-05-05Stream distinct根據(jù)list某個(gè)字段去重的解決方案
這篇文章主要介紹了Stream distinct根據(jù)list某個(gè)字段去重,stream的distinct去重方法,是根據(jù) Object.equals,和 Object.hashCode這兩個(gè)方法來(lái)判斷是否重復(fù)的,本文給大家介紹的非常詳細(xì),需要的朋友可以參考下2023-05-05Java中public關(guān)鍵字用法詳細(xì)講解
這篇文章主要給大家介紹了關(guān)于Java中public關(guān)鍵字用法的相關(guān)資料,public關(guān)鍵字是和訪問(wèn)權(quán)限相關(guān)的,它所修飾的方法對(duì)所有類都是可以訪問(wèn)的,需要的朋友可以參考下2023-09-09