操作系統(tǒng)淘汰算法有哪幾種
操作系統(tǒng)中控制內存進出主要有三種淘汰算法,那么他們各自特點是什么呢。下面由學習啦小編為大家整理了操作系統(tǒng)淘汰算法的相關知識,希望對大家有幫助!
操作系統(tǒng)淘汰算法詳解
操作系統(tǒng)淘汰算法1,F(xiàn)IFO(先進先出算法)
顧名思義,最先被置換進內存的頁面最先出來,公正公平,大家都別搶,但是不一定合理,能者要多勞啊。
最先進去的頁面,比如一些初始化性質的頁面,通常在整個程序運行期間都是需要,被置換出去非常不合理。
操作系統(tǒng)淘汰算法2,NRU(Not Recently Used,最近未使用算法,又稱CLK算法)
a. 給每一幀關聯(lián)一個附加位,稱為使用位
b. 當某一頁首次裝入主存時,該幀的使用位設置為1
c. 當該頁隨后再被訪問到時,它的使用位也被置為1
d. 對于頁替換算法,用于替換的候選幀集合看做一個循環(huán)緩沖區(qū),并且有一個指針與之相關聯(lián)
e. 當某一頁被替換時,該指針被設置成指向緩沖區(qū)中的下一幀
f. 當需要替換一頁時,操作系統(tǒng)掃描緩沖區(qū),以查找使用位被置為0的一幀。每當遇到一個使用位為1的幀時,操作系統(tǒng)就將該位重新置為0
g. 如果在這個過程開始時,緩沖區(qū)中所有幀的使用位均為0,則選擇遇到的第一個幀替換
h. 如果所有幀的使用位均為1,則指針在緩沖區(qū)中完整地循環(huán)一周,把所有使用位都置為0,并且停留在最初的位置上,替換該幀中的頁
操作系統(tǒng)淘汰算法3,LRU(Least Recently Used,最少最近使用算法)
計時法:給頁表中的每一頁增加一個域,專門用來存放計時標志,用來記錄該頁面自上次被訪問以來所經歷的時間。頁面每被訪問一次,計時清0。要裝入新頁時,從內存的頁面中選出時間最長的一頁,調出,同時把各頁的計時標志全部清0,重新開始計時。 計時法可以稍作改變,成為計數(shù)法:頁面被訪問,計數(shù)標志清0,其余所有內存頁面計數(shù)器加1;要裝入新頁時,選出計數(shù)最大的一頁調出,同時所有計數(shù)器清0。
鏈表法:操作系統(tǒng)為每個進程維護一條鏈表,鏈表的每個結點記錄一張頁面的地址。調用一次頁面,則把該頁面的結點從鏈中取出,放到鏈尾;要裝入新頁,則把鏈頭的頁面調出,同時生成調入頁面的結點,放到鏈尾。鏈表法可看作簡單計時/計數(shù)法的改良,維護一個鏈表,自然要比維護所有頁面標志要簡單和輕松。可是,這并沒有在數(shù)量級上改變算法的時間復雜度,每調用一個頁面,都要在鏈表中搜尋對應結點并放至鏈尾的工作量并不算小。