版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
1、<p> 《操作系統(tǒng)》課程設(shè)計說明書</p><p> 設(shè)計題目: 存儲管理 </p><p> 專 業(yè): 計算機科學(xué)與技術(shù) </p><p> 指導(dǎo)教師: </p><p> 班 級:
2、</p><p> 學(xué) 號: </p><p> 姓 名: </p><p> 同 組 人: </p><p><b> 計算機科學(xué)與工程系</b></p>
3、<p> 2013年 01 月 10 日</p><p><b> 前言</b></p><p> 本模擬系統(tǒng)實現(xiàn)了先進先出頁面淘汰算法(FIFO)、最近最少使用LRU頁面淘汰算法、最近未使用算法NUR、最少訪問頁面算法LFU和最佳淘汰算法OPT。同時系統(tǒng)可以隨意設(shè)置當(dāng)前分配給作業(yè)的物理塊數(shù)。</p><p> 系統(tǒng)運行時,
4、任意輸入一個頁面訪問序列,可以設(shè)定不同的頁面置換算法和物理塊數(shù),輸出其頁面淘汰的情況,計算其缺頁次數(shù)和缺頁率。系統(tǒng)結(jié)束后,比較同一個頁面訪問序列,可以得出在不同的頁面置換算法和物理塊數(shù)的情況下,其產(chǎn)生的缺頁次數(shù)和缺頁率。</p><p> 使用FIFO算法,由于測試數(shù)據(jù)相同的頁面比較少,所以采用FIFO算法時,需要置換的頁面多,比較繁瑣,沒有優(yōu)化效果,所以FIFO算法性能不好。使用LRU的算法,此組數(shù)據(jù)顯示LR
5、U的算法使用比較繁瑣,總的來說,NUR、LFU、LRU算法介于FIFO和Optimial之間。通過系統(tǒng)模擬得出,optimal算法的性能高,LRU、NUR、LRU算法的性能次之,F(xiàn)IFO的算法性能最差,較少應(yīng)用;由于optimal算法在實際上難于實現(xiàn),所以實際應(yīng)用一般用LRU算法。</p><p> 本設(shè)計的目的是是熟悉存儲管理的設(shè)計方法,加深對請求分頁式存儲管理的</p><p>
6、認識。設(shè)計中用到了數(shù)據(jù)結(jié)構(gòu)中的相關(guān)知識,鏈表的操作,通過本設(shè)計可以加深的數(shù)據(jù)結(jié)構(gòu)的理解。設(shè)計代碼語言用到的是C語言,使用起來比較方便,可以在虛擬機和VC上直接運行。</p><p><b> 目錄</b></p><p><b> 目錄3</b></p><p><b> 一、系統(tǒng)環(huán)境4</b&g
7、t;</p><p> 1.1、硬件環(huán)境4</p><p> 1.2、軟件環(huán)境4</p><p><b> 二、設(shè)計目的5</b></p><p><b> 三、總體設(shè)計6</b></p><p> 3.1、程序設(shè)計組成框圖6</p><
8、;p><b> 3.2、流程圖7</b></p><p><b> 四、詳細設(shè)計11</b></p><p> 4.1、數(shù)據(jù)結(jié)構(gòu)11</p><p> 4.1.1頁面類型11</p><p> 4.1.2頁面控制結(jié)構(gòu)11</p><p> 4.2.
9、函數(shù)定義12</p><p> 4.3.變量定義12</p><p> 4.4.算法分析12</p><p> 五、調(diào)試與測試14</p><p> 5.1、調(diào)試方法14</p><p> 5.2、測試結(jié)果的分析與討論14</p><p> 六、設(shè)計中遇到的問題15&l
10、t;/p><p> 七、源程序清單16</p><p> 八、總結(jié),收獲與體會25</p><p><b> 九、參考文獻26</b></p><p><b> 一、系統(tǒng)環(huán)境</b></p><p><b> 1.1、硬件環(huán)境</b><
11、/p><p> PC機一臺,內(nèi)存,2.0GHZ主頻</p><p><b> 1.2、軟件環(huán)境</b></p><p> 設(shè)計和實驗將Windows環(huán)境下,gcc和虛擬機軟件VMWare。 </p><p><b> 二、設(shè)計目的</b></p><p> 存儲管理的主
12、要功能之一是合理地分配空間。請求頁式管理是一種常用的虛擬存儲管理技術(shù)。本設(shè)計的目的是通過請求頁式存儲管理中頁面置換算法模擬設(shè)計,了解虛擬存儲技術(shù)的特點,掌握請求頁式存儲管理的頁面置換算法。要求:</p><p> (1)通過隨機數(shù)產(chǎn)生一個指令序列,共320條指令。指令的地址按下述原則生成:</p><p> ?、?0%的指令是順序執(zhí)行的;②25%的指令是均勻分布在前地址部分;③25%的指
13、令是均勻分布在后地址部分。</p><p> 具體的實施方法是:①在[0,319]的指令地址之間隨機選取一起點m;②順序執(zhí)行一條指令,即執(zhí)行地址為m+l的指令;③在前地址[0,m+1]中隨機選取一條指令并執(zhí)行,該指令的地址為m’;④順序執(zhí)行一條指令,其地址為m’+1;⑤在后地址[m’+2,319]中隨機選取一條指令并執(zhí)行;⑥重復(fù)上述步驟①~⑤,直到執(zhí)行320次指令。</p><p>
14、(2)將指令序列變換成為頁地址流。設(shè):①頁面大小為1K;②用戶內(nèi)存容量為4頁到32頁;③用戶虛存容量為32K。</p><p> 在用戶虛存中,按每頁存放10條指令排列虛存地址,即320條指令在虛存中的存放方式為:</p><p> 第0條~第9條指令為第0頁(對應(yīng)虛存地址為[0,9]);</p><p> 第10條~第19條指令為第1頁(對應(yīng)虛存地址為[10
15、,19]);</p><p><b> … … … </b></p><p> 第310條~第319條指令為第31頁(對應(yīng)虛存地址為[310,319])。</p><p> 按以上方式,用戶指令可組成32頁。</p><p> (3)計算并輸出下述各種算法在不同內(nèi)存容量下的命中率(要為以下各種算法定義數(shù)據(jù)結(jié)構(gòu))。
16、</p><p> ?、傧冗M先出的算法(FIFO);</p><p> ?、谧罱钌偈褂盟惴?LRU);</p><p> ?、圩罱畈唤?jīng)常使用算法(NUR/NRU/CLOCK)。</p><p><b> 三、總體設(shè)計</b></p><p> 3.1、程序設(shè)計組成框圖</p>
17、<p><b> 程序設(shè)計組成框圖</b></p><p><b> 3.2、流程圖</b></p><p> FIFO LRU</p><p><b> Y</b></p><p><
18、;b> Y</b></p><p><b> Y</b></p><p><b> N</b></p><p><b> LRU算法</b></p><p><b> NUR算法</b></p><p>
19、<b> OPT算法</b></p><p><b> 四、詳細設(shè)計</b></p><p> 本程序設(shè)計基本按照題目的要求進行。即首先用srand()和rand()函數(shù)定義和產(chǎn)生指令序列,然后將指令序列變成相應(yīng)的頁地址流,并針對不同的算法計算出相應(yīng)的命中率。</p><p><b> 4.1、數(shù)據(jù)結(jié)構(gòu)&
20、lt;/b></p><p><b> 4.1.1頁面類型</b></p><p> Typedef struct{</p><p> Int pn,pfn,count,time;</p><p><b> }pl_type;</b></p><p> 其中p
21、n為頁號,pfn為面號,count為個周期內(nèi)訪問該頁面次數(shù)time為訪問時間。</p><p> 4.1.2頁面控制結(jié)構(gòu)</p><p> pfc_struct{</p><p> intpn,pfn;</p><p> struct pfc_struct*next;</p><p><b>
22、}</b></p><p> typedefstruct pfc_struct pfc_type;</p><p> pfc_typepfc[xy],*free_head,*busy_head;</p><p> pfc_type*busy_tail;</p><p><b> 其中:</b>&
23、lt;/p><p> pfc[xy]定義用戶進程虛頁控制結(jié)構(gòu),</p><p> *free_head為空頁面頭的指針,</p><p> *busy_head為忙頁面頭的指針,</p><p> *busy_tail為忙頁面尾的指針。</p><p><b> 4.2.函數(shù)定義</b>&l
24、t;/p><p> (1)void initialize():初始化函數(shù),給每個相關(guān)的頁面賦值。</p><p> (2)void FIFO():計算使用FIFO算法時的命中率。</p><p> (3)void LRU():計算使用LRU算法時的命中率。</p><p> (4)void OPT():計算使用OPT算法時的命中率。<
25、;/p><p> (5)void LFU():計算使用LFU算法時的命中率。</p><p> (6)void NUR():計算使用NUR算法時的命中率。</p><p><b> 4.3.變量定義</b></p><p> (1)int a[zllc];指令流數(shù)據(jù)組。</p><p> (
26、2)int page[zllc];每條指令所屬頁號。</p><p> (3)int offset[zllc];每頁裝入10條指令后取模運算頁號偏移值。</p><p> (4)int pf:用戶進程的內(nèi)存頁面數(shù)。</p><p> (5)int zhihuan:頁面失效次數(shù)。</p><p><b> 4.4.算法分析&l
27、t;/b></p><p> 先進先出算法,即FIFO算法(First-In First-Out algorithm)。這種算法選擇最先調(diào)入主存儲器的頁面作為被替換的頁面。它的優(yōu)點是比較容易實現(xiàn),能夠利用主儲存器中頁面調(diào)度情況的歷史信息,但是沒有反應(yīng)程序的局部性。因為最先調(diào)入主存的頁面,很有可能是經(jīng)常使用的頁面。</p><p> 最近最少使用算法,即LFU(Least Freq
28、uently used algorithm)。這種算法選擇近期最少訪問的頁面作為被替換的頁面。顯然這是一種非常合理的算法,因為到目前為止最少使用的頁面,和可能也是將來最少訪問的頁面。該算法即充分利用了主存中嗎調(diào)度的歷史信息,又正確反映了程序的局部性。但是這種算法實現(xiàn)起來非常的困難,它要為每個頁面設(shè)置一個很長的計數(shù)器,并且要選擇一個固定的時鐘為每個計數(shù)器定時計數(shù)。在選擇被替換頁面時,要從所有的計數(shù)器中選擇一個計數(shù)值最大的計數(shù)器。因此,通常
29、使用如下一種簡單的方法。</p><p> 最久沒有使用算法。即LRU(Least Recently Used Algorithm)。這種算法把近期最久沒有被訪問的頁面作為被替換的頁面。它把LFU算法中要記錄數(shù)量上的多與少簡化成判斷有于無,因此實現(xiàn)起來比較容易。</p><p> NUR算法在需要淘汰一頁時,從哪些最近一個時期內(nèi)未被訪問的頁面中任選一頁淘汰。只要在頁面中增加一個訪問位即
30、可實現(xiàn)。當(dāng)某頁被訪問時,訪問位置1.否則,訪問位置0.系統(tǒng)周期性第對所有的引用位清零。當(dāng)須淘汰一頁時從那些訪問位為0 的頁中選擇一頁進行淘汰。如果引用位全為1或0,NRU算法退化為FIFO算法。</p><p> 最優(yōu)替換算法,即OPT(Optimal Replacement Algorithm).s上面介紹的幾種頁面替換算法主要是以主存儲器中頁面調(diào)度情況的歷史信息為依據(jù)的,它假設(shè)將來主存儲器中的頁面調(diào)度情況與
31、過去一段時間內(nèi)主存儲器中的頁面調(diào)度情況是相同的。當(dāng)然這種假設(shè)不總是正確的。最好的算法是選擇將來醉酒不被訪問的頁面作為被替換的頁面,這種算法的命中率是最高的,它就是最有替換算法。要實現(xiàn)OPT算法,唯一的辦法就是讓程序先執(zhí)行一遍,記錄下實際的頁地址流情況。根據(jù)這個頁地址流才能找到藥被替換的頁面。顯然這樣做是不現(xiàn)實的。因此OPT算法只是一種理想化的算法,然而它也是一種很用的算法。實際上,經(jīng)常把這種算法作為評價其他頁面替換算法好壞的標(biāo)準(zhǔn)。在其他
32、條件相同的情況下,哪一種算法的命中率與OPT算法最接近,那么,它就是一種比較好的頁面替換算法。</p><p><b> 五、調(diào)試與測試</b></p><p><b> 5.1、調(diào)試方法</b></p><p> 利用Vware虛擬機的命令,用touch創(chuàng)建文件,vi 進入文件,然后編寫代碼,運行程序。</p
33、><p> 2、測試結(jié)果的分析與討論</p><p><b> 調(diào)試運行結(jié)果圖</b></p><p> 5.2、測試結(jié)果的分析與討論</p><p> 使用FIFO算法需要置換的頁面多,比較繁瑣,沒有優(yōu)化效果,所以FIFO算法性能不好。LRU的算法,此組數(shù)據(jù)顯示LRU的算法使用比較繁瑣,總的來說,NUR、LFU、L
34、RU算法介于FIFO和Optimial之間。通過系統(tǒng)模擬得出,optimal算法的性能高,LRU、NUR、LRU算法的性能次之,F(xiàn)IFO的算法性能最差,較少應(yīng)用;由于optimal算法在實際上難于實現(xiàn),所以實際應(yīng)用一般用LRU算法。</p><p> 六、設(shè)計中遇到的問題</p><p> 本次課程設(shè)計中我們遇到的問題是,一開始沒有弄清楚rand和sand函數(shù)的使用方法,以至于運行時的
35、到的結(jié)果與實際算起來的不相符,后來查閱資料,上網(wǎng)瀏覽搜索相關(guān)信息后,終于弄明白了是怎么回事。</p><p> 函數(shù)rand()是真正的隨機數(shù)生成器,而srand()會設(shè)置供rand()使用的隨機數(shù)種子。如果你在第一次調(diào)用rand()之前沒有調(diào)用srand(),那么系統(tǒng)會為你自動調(diào)用srand()。而使用同種子相同的數(shù)調(diào)用 srand()會導(dǎo)致相同的隨機數(shù)序列被生成。 </p><p>
36、 srand((unsigned)time(NULL))則使用系統(tǒng)定時/計數(shù)器的值做為隨機種子。每個種子對應(yīng)一組根據(jù)算法預(yù)先生成的隨機數(shù),所以,在相同的平臺環(huán)境下,不同時間產(chǎn)生的隨機數(shù)會是不同的,相應(yīng)的,若將srand(unsigned)time(NULL)改為srand(TP)(TP為任一常量),則無論何時運行、運行多少次得到的“隨機數(shù)”都會是一組固定的序列,因此srand生成的隨機數(shù)是偽隨機數(shù)。</p><p&
37、gt; 還有就是開始代碼編寫完了之后,運行時OPT算法結(jié)果出錯。這個問題是在我們討論并仔細查看OPT算法的內(nèi)容后修改的。</p><p><b> 七、源程序清單</b></p><p> #include<stdlib.h></p><p> #include<stdio.h></p><p
38、> #include<time.h></p><p> #define TRUE 1</p><p> #define FALSE 0</p><p> #define INVALID -1</p><p> #define zllc 320 //指令流長</p><p> #define
39、 xy 32 //虛頁長</p><p> #define clear 50 //清零周期</p><p> typedef struct //頁面結(jié)構(gòu)</p><p><b> {</b></p><p> int pn;//頁號</p><p> int pfn;//頁面框架號<
40、;/p><p> int count; //計數(shù)器</p><p> int time;//時間</p><p><b> }pc;</b></p><p> pc pl[xy];//頁面線性結(jié)構(gòu)</p><p> typedef struct pfc_struct//頁面控制結(jié)構(gòu),調(diào)度算法
41、的控制結(jié)構(gòu)</p><p><b> {</b></p><p><b> int pn;</b></p><p><b> int pfn;</b></p><p> struct pfc_struct *next;</p><p> }pf
42、c_type;</p><p> pfc_type pfc[xy],*free_head,*busy_head,*busy_tail;</p><p> int zhihuan,a[zllc];//a[] 為指令序列</p><p> int page[zllc],offset[zllc];//地址信息</p><p> int in
43、itialize(int);//初始化模塊</p><p> int FIFO(int);//FIFO調(diào)度算法</p><p> int LRU(int);//LRU調(diào)度算法</p><p> int LFU(int);//LFU調(diào)度算法</p><p> int NUR(int);//NUR調(diào)度算法</p><p
44、> int OPT(int);//OPT調(diào)度算法</p><p><b> /*主函數(shù)*/</b></p><p> int main()</p><p><b> {</b></p><p><b> int s,i;</b></p><p
45、> srand((unsigned)time(NULL));</p><p> s = rand()%320;</p><p> for(i=0;i<zllc;i += 4)</p><p><b> {</b></p><p> if(s<0||s>319)</p>&l
46、t;p><b> {</b></p><p> printf("When i == %d,Error,s==%d",i,s);</p><p><b> exit(0);</b></p><p><b> }</b></p><p><b
47、> a[i] = s;</b></p><p> a[i+1] = a[i]+1;</p><p> a[i+2] = rand()%(a[i+1]+1);</p><p> a[i+3] = a[i+2] + 1;</p><p> s = rand()%(319-a[i+3]) +a[i+3]+1;</p
48、><p> if(a[i+2]>318||s>319)</p><p><b> {</b></p><p> printf("a[%d+2],a number which is:%d and s == %d\n",i,a[i+2],s);</p><p><b> }<
49、;/b></p><p><b> }</b></p><p> for(i=0;i<zllc;i++)//將指令序列變換為頁地址流</p><p><b> {</b></p><p> page[i] = a[i]/10;</p><p> offs
50、et[i] = a[i]%10;</p><p><b> }</b></p><p> for(i=4;i<=32;i++)</p><p><b> {</b></p><p> printf("%2d page frames:\t",i);</p>
51、<p><b> FIFO(i);</b></p><p><b> LRU(i);</b></p><p><b> LFU(i);</b></p><p><b> NUR(i);</b></p><p><b> O
52、PT(i);</b></p><p><b> }</b></p><p><b> return 0;</b></p><p><b> }</b></p><p> /*初始化相關(guān)的數(shù)據(jù)結(jié)構(gòu),pf表示內(nèi)存的塊數(shù)*/</p><p>
53、; int initialize(int pf)</p><p><b> {</b></p><p><b> int i;</b></p><p> zhihuan = 0;</p><p> for(i=0;i<xy;i++)</p><p><b
54、> {</b></p><p> pl[i].pn = i;</p><p> pl[i].pfn = INVALID;//質(zhì)頁面控制結(jié)構(gòu)中的頁號,頁面為空</p><p> pl[i].count = 0;//頁面控制結(jié)構(gòu)中訪問次數(shù)</p><p> pl[i].time = -1;//訪問時間</p>
55、;<p><b> }</b></p><p> for(i=0;i<pf-1;i++)//建立pfc[i-1]與pfc[i]之間的聯(lián)系</p><p><b> {</b></p><p> pfc[i].next = &pfc[i+1];</p><p>
56、pfc[i].pfn = i;</p><p><b> }</b></p><p> pfc[pf-1].next = NULL;</p><p> pfc[pf-1].pfn = pf-1;</p><p> free_head = &pfc[0];//空頁面隊列的頭指針為pfc[0]</p&g
57、t;<p><b> return 0;</b></p><p><b> }</b></p><p> /*先進先出算法,pf為用戶進程的內(nèi)存頁面數(shù)*/</p><p> int FIFO(int pf)</p><p><b> {</b></
58、p><p><b> int i;</b></p><p> pfc_type *p;//中間變量</p><p> initialize(pf);//初始化數(shù)據(jù)結(jié)構(gòu)</p><p> busy_head = busy_tail = NULL;//忙頁面頭隊列,為隊列鏈接</p><p>
59、for(i=0;i<zllc;i++)</p><p><b> {</b></p><p> if(pl[page[i]].pfn == INVALID)//頁面失效</p><p><b> {</b></p><p> zhihuan++;//失效次數(shù)</p>&l
60、t;p> if(free_head == NULL)//無空閑頁面</p><p><b> {</b></p><p> p = busy_head->next;//保存忙頁面的下一個頁面</p><p> pl[busy_head->pn].pfn = INVALID;//把這個頁面換出,更新它的數(shù)據(jù)成員</
61、p><p> free_head = busy_head;//釋放忙頁面隊列的第一個頁面</p><p> free_head->next = NULL;//表明此頁面是空的組后一面</p><p> busy_head = p;//更新頁面的頭隊列指針</p><p><b> }</b></p>
62、<p> p = free_head->next;</p><p> free_head->pn = page[i];</p><p> pl[page[i]].pfn = free_head->pfn;</p><p> free_head->next = NULL;//使busy的尾為空</p><
63、;p> if(busy_tail == NULL)</p><p><b> {</b></p><p> busy_tail = busy_head = free_head;</p><p><b> }</b></p><p><b> else</b>&l
64、t;/p><p><b> {</b></p><p> //把剛剛換進來的接在busy_tail的后面</p><p> busy_tail->next = free_head;</p><p> busy_tail = free_head;</p><p><b> }&
65、lt;/b></p><p> free_head = p;//下一個空頁面</p><p><b> }</b></p><p><b> }</b></p><p> printf("FIFO:%6.4f|",1-(float)zhihuan/320);<
66、;/p><p><b> return 0;</b></p><p><b> }</b></p><p> /*最近最久未使用算法*/</p><p> int LRU(int pf)</p><p><b> {</b></p>
67、<p> int min,minj,i,j,present_time;//minj為最小值下標(biāo)</p><p> initialize(pf);</p><p> present_time=0;</p><p> for(i=0;i<zllc;i++)</p><p><b> {</b><
68、;/p><p> if(pl[page[i]].pfn == INVALID)//頁面失效</p><p><b> {</b></p><p> zhihuan++;</p><p> if(free_head == NULL)//無空閑頁面</p><p><b> {<
69、/b></p><p> min = 32767;//設(shè)置最大值</p><p> for(j=0;j<xy;j++)//找出time最下值</p><p><b> {</b></p><p> if(min>pl[j].time&&pl[j].pfn!=INVALID)<
70、;/p><p><b> {</b></p><p> min = pl[j].time;</p><p><b> minj = j;</b></p><p><b> }</b></p><p><b> }</b><
71、;/p><p> free_head = &pfc[pl[minj].pfn];//騰出一個單元</p><p> pl[minj].pfn = INVALID;</p><p> pl[minj].time = 0;</p><p> free_head->next= NULL;</p><p>&
72、lt;b> }</b></p><p> pl[page[i]].pfn = free_head->pfn;//有空閑頁面改為有效</p><p> pl[page[i]].time =present_time;</p><p> free_head = free_head->next;//減少一個free頁面</p>
73、;<p><b> }</b></p><p><b> else</b></p><p><b> {</b></p><p> pl[page[i]].time = present_time;//命中則增加該頁面的訪問次數(shù)</p><p><b&
74、gt; }</b></p><p> present_time++;</p><p><b> }</b></p><p> printf("LRU:%6.4f|",1-(float)zhihuan/320);</p><p><b> return 0;</b
75、></p><p><b> }</b></p><p> /*最近未使用算法*/</p><p> int NUR(int pf)</p><p><b> {</b></p><p> int i,j,dp,cont_flag,old_dp;//這個算法用
76、count用于訪問位</p><p> initialize(pf);</p><p><b> dp = 0;</b></p><p> for(i=0;i<zllc;i++)</p><p><b> {</b></p><p> if(pl[page[i
77、]].pfn == INVALID)//頁面失效</p><p><b> {</b></p><p> zhihuan++;</p><p> if(free_head == NULL)//無空閑頁</p><p><b> {</b></p><p> cont
78、_flag = TRUE;</p><p> old_dp = dp;</p><p> while(cont_flag)//找到一訪問位count為0的頁面</p><p><b> {</b></p><p> if(pl[dp].count == 0 && pl[dp].pfn != INV
79、ALID)</p><p><b> {</b></p><p> cont_flag = FALSE;</p><p><b> }</b></p><p> else//下一個頁面</p><p><b> {</b></p>
80、<p> pl[dp].count = 0;</p><p><b> dp++;</b></p><p> if(dp==xy)//32個頁面找一遍,開始新的循環(huán)</p><p><b> dp=0;</b></p><p><b> }</b><
81、/p><p><b> }</b></p><p> free_head = &pfc[pl[dp].pfn];</p><p> pl[dp].pfn = INVALID;</p><p> free_head->next = NULL;</p><p><b>
82、}</b></p><p> pl[page[i]].pfn = free_head->pfn;</p><p> pl[page[i]].count = 1;</p><p> free_head->pn = page[i];</p><p> free_head = free_head->next;&
83、lt;/p><p><b> }</b></p><p><b> else</b></p><p><b> {</b></p><p> pl[page[i]].count = 1;</p><p><b> }</b>&
84、lt;/p><p> if(i%clear == 0)</p><p> for(j=0;j<xy;j++)</p><p> pl[j].count = 0;</p><p><b> }</b></p><p> printf("NUR:%6.4f|",1-(
85、float)zhihuan/320);</p><p><b> return 0;</b></p><p><b> }</b></p><p> /*最少訪問頁面算法*/</p><p> int LFU(int pf)</p><p><b> {&
86、lt;/b></p><p> int i,j,min,minpage;</p><p> initialize(pf);</p><p> for(i=0;i<zllc;i++)</p><p><b> {</b></p><p> if(pl[page[i]].pfn
87、== INVALID)//頁面失效</p><p><b> {</b></p><p> zhihuan++;</p><p> if(free_head == NULL)//無空閑頁面</p><p><b> {</b></p><p> min = 3276
88、7;//獲取count的使用頻率最小的內(nèi)存</p><p> for(j=0;j<xy;j++)</p><p><b> {</b></p><p> if(min>pl[j].count&&pl[j].pfn!=INVALID)</p><p><b> {</b&
89、gt;</p><p> min = pl[j].count;</p><p> minpage=j;</p><p><b> }</b></p><p><b> }</b></p><p> free_head = &pfc[pl[minpage].p
90、fn];</p><p> pl[minpage].pfn = INVALID;</p><p> pl[minpage].count=0;</p><p> free_head->next=NULL;</p><p><b> }</b></p><p> pl[page[i]]
91、.pfn = free_head->pfn;</p><p> pl[page[i]].count++;</p><p> free_head = free_head->next;//減少一個free頁面</p><p><b> }</b></p><p><b> else</b&
92、gt;</p><p><b> {</b></p><p> pl[page[i]].count = pl[page[i]].count+1;</p><p><b> }</b></p><p><b> }</b></p><p> pr
93、intf("LFU:%6.4f",1-(float)zhihuan/320);</p><p><b> return 0;</b></p><p><b> }</b></p><p> /*最佳置換算法*/</p><p> int OPT(int pf)</
94、p><p><b> {</b></p><p> int i,j,k,l,max,maxpage;</p><p> initialize(pf);</p><p> for(i = 0; i < zllc; i++)</p><p><b> {</b><
95、;/p><p> if(pl[page[i]].pfn == INVALID)//頁面失效</p><p><b> { </b></p><p> zhihuan++;</p><p> max = maxpage = 0;</p><p> if(free_head == NULL)
96、//無頁面空閑</p><p><b> {</b></p><p> for(j = 0; j < pf; j++)</p><p><b> {</b></p><p><b> l = 1;</b></p><p> for(k =
97、 i + 1; k < zllc; k++)</p><p><b> {</b></p><p> if(pfc[j].pn == page[k])</p><p><b> {</b></p><p> if(max < l)</p><p><
98、b> {</b></p><p><b> max = l;</b></p><p> maxpage = j;</p><p><b> }</b></p><p><b> break;</b></p><p><b
99、> }</b></p><p><b> l++;</b></p><p><b> }</b></p><p> if(k == 320)</p><p> maxpage = j;</p><p><b> }</b>&
100、lt;/p><p> free_head = &pfc[maxpage];</p><p> free_head->next = NULL;</p><p> pl[pfc[maxpage].pn].pfn = INVALID;</p><p><b> }</b></p><p&g
101、t; pl[page[i]].pfn = free_head->pfn;</p><p> free_head->pn = pl[page[i]].pn ;</p><p> free_head = free_head->next ;</p><p><b> }</b></p><p><
102、;b> }</b></p><p> printf("OPT:%6.4f\n",1-(float)zhihuan/320);</p><p><b> return 0;</b></p><p><b> }</b></p><p> 八、總結(jié),收獲
103、與體會</p><p> 在本次操作系統(tǒng)課程設(shè)計,我采用C實現(xiàn)請求頁式管理缺頁中段模擬設(shè)計的隨機和LRU淘汰算法。首先,應(yīng)了解虛擬存儲器和頁式存儲管理的有關(guān)內(nèi)容,并掌握隨機和LRU淘汰算法的核心思想及具體的流程。然后,在這個基礎(chǔ)上,結(jié)合所掌握的C編程方法和技巧,編寫正確的算法。</p><p> 隨機淘汰算法比較容易實現(xiàn),當(dāng)需要調(diào)入一個新頁面進入內(nèi)存時,用rand()函數(shù)產(chǎn)生的隨機數(shù),
104、作為將要被淘汰的內(nèi)存物理塊號,然后修改頁表內(nèi)容即可。LRU算法就顯得復(fù)雜一些,其核心問題在于怎樣找到內(nèi)存中最近最少使用的那個頁面。 最初設(shè)計這個算法時,出現(xiàn)了一點問題,在某種情況下,會淘汰剛剛被訪問過的頁面。經(jīng)過修改,彌補了這個不足之處,算法的運行結(jié)果正確。 </p><p> 從這次的課程設(shè)計中,我有很大收獲。首先,鞏固了所學(xué)的有關(guān)頁式存儲管理的相關(guān)知識,更深層次地理解并掌握了LRU和隨機淘汰算法的
105、精髓。通過使用C語言模擬LRU和隨機算法實現(xiàn)請求頁式管理,進一步提高了我的編程能力,并且有助于將操作系統(tǒng)和C有機地結(jié)合起來,使我更加明白了學(xué)科之間是緊密聯(lián)系的。 此外,經(jīng)過這次課程設(shè)計,我更加感悟到了,僅僅學(xué)習(xí)書本上的理論知識是不夠的,要在平時多進行實際操作,這樣才能融會貫通,更加牢固地掌握所學(xué)知識。在以后的學(xué)習(xí)過程中,我應(yīng)該更加深入學(xué)習(xí)有關(guān)C的內(nèi)容,提高自己的動手能力。</p><p><b> 九
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 模擬頁式存儲管理-操作系統(tǒng)課程設(shè)計
- 模擬頁式存儲管理 操作系統(tǒng)課程設(shè)計
- 操作系統(tǒng)課程設(shè)計--請求頁式存儲管理
- 操作系統(tǒng)課程設(shè)計--請求頁式存儲管理
- 操作系統(tǒng)課程設(shè)計--- 請求調(diào)頁存儲管理
- 操作系統(tǒng)課程設(shè)計--請求頁式存儲管理
- 虛擬存儲器管理系統(tǒng)操作系統(tǒng)課程設(shè)計
- 操作系統(tǒng)課程設(shè)計---文件加密存儲
- 操作系統(tǒng)課程設(shè)計——操作系統(tǒng)課程設(shè)計模擬操作系統(tǒng)
- 內(nèi)存管理(操作系統(tǒng))操作系統(tǒng)課程設(shè)計
- 操作系統(tǒng)課程設(shè)計---動態(tài)分區(qū)分配存儲管理
- 操作系統(tǒng)課程設(shè)計--模擬實現(xiàn)可變分區(qū)存儲管理
- 操作系統(tǒng)原理課程設(shè)計報告-可變分區(qū)存儲管理
- 模擬頁式存儲管理-操作系統(tǒng)課程設(shè)計報告
- 操作系統(tǒng)課程設(shè)計-- 操作系統(tǒng)
- 操作系統(tǒng)課程設(shè)計--模擬請求頁式存儲管理
- 操作系統(tǒng)課程設(shè)計---進程管理系統(tǒng)
- 操作系統(tǒng)課程設(shè)計--文件管理系統(tǒng)
- 操作系統(tǒng)課程設(shè)計
- 操作系統(tǒng)課程設(shè)計
評論
0/150
提交評論