




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、.軟 件 學(xué) 院上 機(jī) 實(shí) 驗(yàn) 報(bào) 告課程名稱: 操作系統(tǒng)原理 實(shí)驗(yàn)項(xiàng)目: 虛擬內(nèi)存頁(yè)面置換算法 實(shí) 驗(yàn) 室: 地獄018 姓 名: 死神 學(xué) 號(hào): 專業(yè)班級(jí): 實(shí)驗(yàn)時(shí)間: 2015/12/13 實(shí)驗(yàn)成績(jī)?cè)u(píng)閱教師一、 實(shí)驗(yàn)?zāi)康募耙笸ㄟ^這次實(shí)驗(yàn),加深對(duì)虛擬內(nèi)存頁(yè)面置換概念的理解,進(jìn)一步掌握先進(jìn)先出FIFO、最佳置換OPI和最近最久未使用LRU頁(yè)面置換算法的實(shí)現(xiàn)方法。結(jié)合Linux的內(nèi)層的分析方法查看內(nèi)存的分配過程及l(fā)inux kernel的內(nèi)存管理機(jī)制二、 實(shí)驗(yàn)性質(zhì)設(shè)計(jì)性三、 實(shí)驗(yàn)學(xué)時(shí) 4學(xué)時(shí)四、 實(shí)驗(yàn)環(huán)境實(shí)驗(yàn)環(huán)境1.實(shí)驗(yàn)環(huán)境: C與C+程序設(shè)計(jì)學(xué)習(xí)與實(shí)驗(yàn)系統(tǒng)2.知識(shí)準(zhǔn)備:(1)使用Linux
2、的基本命令;(2)了解Linux vmstat、free、top等命令查看linux系統(tǒng)的內(nèi)存分配情況;(3) 掌握虛擬內(nèi)存頁(yè)面置換算法FIFO等基本算法理論。五、 實(shí)驗(yàn)內(nèi)容及步驟假設(shè)有n個(gè)進(jìn)程分別在T1, ,Tn時(shí)刻到達(dá)系統(tǒng),它們需要的服務(wù)時(shí)間分別為S1, ,Sn。分別采用先來先服務(wù)FCFS和短作業(yè)優(yōu)先SJF進(jìn)程調(diào)度算法進(jìn)行調(diào)度,計(jì)算每個(gè)進(jìn)程的完成時(shí)間、周轉(zhuǎn)時(shí)間和帶權(quán)周轉(zhuǎn)時(shí)間,并且統(tǒng)計(jì)n個(gè)進(jìn)程的平均周轉(zhuǎn)時(shí)間和平均帶權(quán)周轉(zhuǎn)時(shí)間。步驟通過已知最小物理塊數(shù)、頁(yè)面?zhèn)€數(shù)、頁(yè)面訪問序列、及采用置換方式可以得出頁(yè)面置換的缺頁(yè)次數(shù)和缺頁(yè)率,及每次缺頁(yè)時(shí)物理塊中存儲(chǔ)。1輸入的形式 int PageOrderM
3、axNumber;/頁(yè)面序列int PageNum,LackNum=0,BlockNum;/頁(yè)面?zhèn)€數(shù),缺頁(yè)次數(shù),最小物理塊數(shù)2. 輸出的形式double LackPageRate/缺頁(yè)率缺頁(yè)個(gè)數(shù)每次缺頁(yè)時(shí)物理塊中存儲(chǔ) 程序所能達(dá)到的功能模擬先進(jìn)先出FIFO、最佳置換OPI和最近最久未使用LRU頁(yè)面置換算法的工作過程。假設(shè)內(nèi)存中分配給每個(gè)進(jìn)程的最小物理塊數(shù)為m,在進(jìn)程運(yùn)行過程中要訪問的頁(yè)面?zhèn)€數(shù)為n,頁(yè)面訪問序列為P1, ,Pn,分別利用不同的頁(yè)面置換算法調(diào)度進(jìn)程的頁(yè)面訪問序列,給出頁(yè)面訪問序列的置換過程,計(jì)算每種算法缺頁(yè)次數(shù)和缺頁(yè)率。測(cè)試數(shù)據(jù),包括正確的輸入及其輸出結(jié)果和含有錯(cuò)誤的輸入及其輸出結(jié)
4、果。程序中用到的所有抽象數(shù)據(jù)類型的定義、主程序的流程以及各程序模塊之間的層次(調(diào)用)關(guān)系。int PageOrderMaxNumber;/頁(yè)面序列int PageCountMaxNumber=0;/計(jì)算內(nèi)存內(nèi)數(shù)據(jù)離下一次出現(xiàn)的距離int PageNum,LackNum=0,BlockNum;/頁(yè)面?zhèn)€數(shù),缺頁(yè)次數(shù),最小物理塊數(shù)double LackPageRate=0;bool found=false;六、實(shí)驗(yàn)數(shù)據(jù)及結(jié)果分析運(yùn)行截圖: 圖6.1圖6.2圖6.3七、實(shí)驗(yàn)總結(jié)這次試驗(yàn),讓我加深了對(duì)虛擬內(nèi)存頁(yè)面置換算法的理解,進(jìn)一步掌握先進(jìn)先出FIFO、最佳置換OPI和最近最久未使用LRU頁(yè)面置換算法
5、的實(shí)現(xiàn)方法。熟悉Linux需要經(jīng)過大量的實(shí)驗(yàn)、改進(jìn)與思考,在編寫代碼的過程中遇到了一些問題要積極面對(duì)并通過討論上網(wǎng)或者問老師解決。通過這次試驗(yàn)我了解了虛擬內(nèi)存置換算法的一些知識(shí),是我對(duì)于所學(xué)習(xí)的專業(yè)知識(shí)得到了更好的鞏固和提升。附錄 源程序清單#include using namespace std;#define MaxNumber 100void OPI(int PageOrderMaxNumber,int PageCountMaxNumber, int PageNum,int LackNum,int BlockNum, double LackPageRate,bool found) int
6、 moduleMaxNumber; int sum=0; int i,j,k,m; for(i=0;iBlockNum;i+)/將內(nèi)存填滿 modulei=PageOrderi; sum+; for(j=0;j=i;j+) coutmodulej ; coutendl; LackNum=BlockNum; for(i=BlockNum;iPageNum;i+) found=false; for(j=0;jBlockNum;j+ )/遍歷已存儲(chǔ),判斷是否缺頁(yè) if(modulej=PageOrderi) found=true; break; if(found=false)/缺頁(yè),選擇替換 for
7、(j=0;jBlockNum;j+) /計(jì)算內(nèi)存內(nèi)數(shù)據(jù)離下一次出現(xiàn)的距離 PageCountj=0; for(k=i+1;kPageNum;k+) if(modulej!=PageOrderk) PageCountj+; else break; int max=PageCount0; int kind=0; for(j=0;jmax) max=PageCountj; kind=j; modulekind=PageOrderi; LackNum+; for(m=0; m3;m+) coutmodulem ; coutendl; LackPageRate=(LackNum*1.0)/PageNum
8、; cout該算法缺頁(yè)次數(shù)為:LackNumendl; cout該算法缺頁(yè)率為:LackPageRate*100%endl;/*先進(jìn)先出置換算法*/void FIFO(int PageOrderMaxNumber,int PageCountMaxNumber, int PageNum,int LackNum,int BlockNum, double LackPageRate,bool found) int moduleMaxNumber; int sum=0; int i,j,m; for(i=0;iBlockNum;i+)/將內(nèi)存填滿 modulei=PageOrderi; sum+; Pa
9、geCounti=3-i; for(j=0;j=i;j+) coutmodulej ; coutendl; LackNum=BlockNum; for(i=BlockNum;iPageNum;i+) found=false; for(j=0;jBlockNum;j+ )/遍歷已存儲(chǔ),判斷是否缺頁(yè) if(modulej=PageOrderi) found=true; break; if(found=false)/缺頁(yè),選擇替換 int max=PageCount0; int kind=0; for(j=0;jmax) max=PageCountj; kind=j; for(int k=0;kBl
10、ockNum;k+)/不是最大值,則要+1 if(k!=kind) PageCountk+; modulekind=PageOrderi; PageCountkind=0;/ 替換之后已經(jīng)查詢的次數(shù)改為0 LackNum+; for(m=0; m3;m+) coutmodulem ; coutendl; LackPageRate=(LackNum*1.0)/PageNum; cout該算法缺頁(yè)次數(shù)為:LackNumendl; cout該算法缺頁(yè)率為:LackPageRate*100%endl;/*最近最久未使用置換算法*/void LRU(int PageOrderMaxNumber,int
11、PageCountMaxNumber, int PageNum,int LackNum,int BlockNum, double LackPageRate,bool found) int moduleMaxNumber; int sum=0; int i,j,m; for(i=0;iBlockNum;i+)/將內(nèi)存填滿 modulei=PageOrderi; sum+; PageCounti=3-i; for(j=0;j=i;j+) coutmodulej ; coutendl; LackNum=BlockNum; for(i=BlockNum;iPageNum;i+) found=false
12、; for(j=0;jBlockNum;j+)/遍歷已存儲(chǔ),判斷是否缺頁(yè) if(modulej=PageOrderi) found=true; PageCountj=0;/查詢后,更改次數(shù) for(int k=0;kBlockNum;k+) if(k!=j) PageCountk+; break; if(found=false)/缺頁(yè),選擇替換 int max=PageCount0; int kind=0; for(j=0;jmax) max=PageCountj; kind=j; for(int k=0;kBlockNum;k+) if(k!=kind) PageCountk+; modul
13、ekind=PageOrderi; PageCountkind=0;/ 替換之后未查詢的次數(shù)改為0 LackNum+; for(m=0; m3;m+) coutmodulem ; coutendl; LackPageRate=(LackNum*1.0)/PageNum; cout該算法缺頁(yè)次數(shù)為:LackNumendl; cout該算法缺頁(yè)率為:LackPageRate*100%endl;int main () int PageOrderMaxNumber;/頁(yè)面序列int PageCountMaxNumber=0;/計(jì)算內(nèi)存內(nèi)數(shù)據(jù)離下一次出現(xiàn)的距離int PageNum,LackNum=0,BlockNum;/頁(yè)面?zhèn)€數(shù),缺頁(yè)次數(shù),最小物理塊數(shù)double LackPageRate=0;bool found=false;int chioce1=0,chioce2,chioce3; int i=0;while(chioce1=0)coutchioce2;if(chioce2=1) cout PageNum;coutBlockNum;cout請(qǐng)輸入頁(yè)面序列:endl;for(i=0;iPageOrderi;coutchioce3; if(chioce3=1) FIFO(PageOrder,PageCount,PageNum,LackNum, Bloc
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 經(jīng)濟(jì)責(zé)任審計(jì)報(bào)告
- 2025年度高校畢業(yè)生就業(yè)實(shí)習(xí)保障協(xié)議書
- 2025年度馬術(shù)俱樂部項(xiàng)目合作協(xié)議書-馬術(shù)俱樂部青少年馬術(shù)俱樂部合作約定
- 二零二五年度政府辦公樓無償租用合同書
- 大連市2025年度租賃房屋押金管理合同
- 二零二五年度智慧城市建設(shè)項(xiàng)目多人合伙股東協(xié)議書
- 二零二五年度木材銷售代理服務(wù)合同樣本
- 2025年度湖南省勞動(dòng)合同電子檔案管理規(guī)范
- 二零二五年度租車保險(xiǎn)配套服務(wù)合同模板
- 二零二五年度展會(huì)現(xiàn)場(chǎng)醫(yī)療急救服務(wù)合同
- 靜脈治療??谱o(hù)士培訓(xùn)
- 兒童歌曲課件教學(xué)課件
- 牛買賣合同范本
- 2024-2030年中國(guó)氣象服務(wù)行業(yè)運(yùn)營(yíng)優(yōu)勢(shì)分析與投資戰(zhàn)略規(guī)劃研究報(bào)告
- 勞務(wù)派遣投標(biāo)方案(交通協(xié)管員外包項(xiàng)目)(技術(shù)方案)
- 金庸人物課件
- 2024年普通高等學(xué)校招生全國(guó)統(tǒng)一考試·新課標(biāo)卷(化學(xué))附試卷分析
- 人教版五年級(jí)下冊(cè)數(shù)學(xué)第2單元測(cè)試題帶答案
- 再生資源門店加盟協(xié)議書
- DB62-T 3268-2024 人民防空工程平戰(zhàn)功能轉(zhuǎn)換技術(shù)標(biāo)準(zhǔn)
- 天車工技能競(jìng)賽理論考試題庫(kù)500題(含答案)
評(píng)論
0/150
提交評(píng)論