


版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、操作系統(tǒng)頁(yè)面置換算法實(shí)驗(yàn)報(bào)告實(shí)驗(yàn)源碼:#include stdio.h#include #include #define DataMax 100DataMax#define BlockNum 10BlockNum/常量/常量int DataShowBlockNum DataMax;儲(chǔ)要顯示的數(shù)組/用于存bool DataShowEnableBlockNum DataMax;/ 用于存儲(chǔ)數(shù)組中的數(shù)據(jù)是否需要顯示 int DataDataMax;int BlockBlockNum;int countBlockNum;int N;int M;/保存數(shù)據(jù)/物理塊/計(jì)數(shù)器/頁(yè)面?zhèn)€數(shù)/最小物理塊/缺頁(yè)次數(shù)
2、/輸入數(shù)據(jù)的/輸出數(shù)據(jù)/ FIFO函數(shù)/ / Optimal 函/ LRU函數(shù)菜單選擇lzf-數(shù)int ChangeTimes;void Datalnput();函數(shù)void DataOutput();的函數(shù)void FIFO();void Optimal();數(shù)void LRU();int main(int argc, char* argv)Datalnput();int menu;while(true)printf(nn1-Optimal2- FIFO3- LRU4-返回上一級(jí)O-EXITprintf(*nH);printf(n*nM);printf(n*nH);printf(n*nn);
3、printf(n*nM);printfC*nM);H*scan f%dH, &menu);switch(menu)case 1:Optimal();break;case 2:FIFO(); break;case 3:LRU();break;case 0:exit(O); break;case 4: system(uclsM); DatalnputO; break;辻(menu != 1 & menu != 2 & menu != 3 & menu != 0 & menu !=4) systemcis”);printf(n請(qǐng)輸入0 - 4之間的整數(shù)! n); continue;return 0;
4、void Datalnput()int i,choice;printf(請(qǐng)輸入最小物理塊數(shù):”); scanf(n%dn?&M);/輸入最小物理塊數(shù)大于數(shù)據(jù)個(gè)數(shù)while(M BlockNum)printfC*物理塊數(shù)超過預(yù)定值,請(qǐng)重新輸入:“);scanf(M%dH,&M);printfC請(qǐng)輸入頁(yè)面的個(gè)數(shù):”); scanf(n%dH,&N);/輸入頁(yè)面的個(gè)數(shù)大于數(shù)據(jù)個(gè)數(shù) while(N DataMax)printf(頂面?zhèn)€數(shù)超過預(yù)定值,請(qǐng)重新輸入:”); scanf (”d”,&N);printfCif選擇產(chǎn)生頁(yè)面訪問序列的方式(1隨機(jī)2.輸入):”); scanf(u%d, &choic
5、e);switch(choice)case 1:/產(chǎn)生隨機(jī)訪問序列for(i = 0;i N;i+)Datai = (int)(float) rand() / 32767) * 10);/隨機(jī)數(shù)大小在0-9之間system(ncls);/顯示隨機(jī)產(chǎn)生的訪問序列printfCAn隨機(jī)產(chǎn)生的訪問序列為:”);for(i = 0;i v N;i+)printf(u%d M,Datai);printf(,nn);break;case 2:/輸入訪問序列printf(請(qǐng)輸入頁(yè)面訪問序列:rT);for(i = 0;i N;i+)scanfCd&Datali);systemCls);/顯示輸入的訪問序列p
6、rintf(nn輸入的訪問序列為:”);for(i = 0;i v N;i+)printf(n%d M,Datai);printf(Hnn);break;default:while(choice != 1 & choice != 2)printfC請(qǐng)輸入1或2選擇相應(yīng)方式門; scanf(%dM, &choice);break;void DataOutput()int i,j;/對(duì)所有數(shù)據(jù)操作for(i = 0;i N;i+)printf(n%d u,Datai);printf(Mn);for(j = 0;j M;汁+)/對(duì)所有數(shù)據(jù)操作for(i = 0;i v N;i+)if( DataSh
7、owEnablej i) printf(%d n,DataShowji);elseprintf ”);printfCAn);printf(缺頁(yè)次數(shù):%dn,ChangeTimes);printf(缺頁(yè)率:%d %nM,ChangeTimes * 100 / N);/最佳置換算法void Optimal()bool find;int point;int temp; /臨時(shí)變量,比較離的最遠(yuǎn)的時(shí)候用int m = l,n;ChangeTimes = 0;for(j = 0;j M;汁+)for(i=0;i N;i+)DataShowEnableji = false; / 初始化為 false,表示
8、沒有要顯示的數(shù)據(jù)for(i = 0;i M;i+)counti = 0 ; /初始化計(jì)數(shù)器/確定當(dāng)前頁(yè)面是否在物理塊中,在繼續(xù),不在置換/ /Block0 = DataO;for(i = l;m M;i+)int flag = 1;for(n = 0; n m;n+)if(Datai = Blockn) flag = 0;if (flag = 0) continue;Blockm = Datai;m+;/ /對(duì)所有數(shù)據(jù)進(jìn)行操作 for(i=0;i N;i+)/表示塊中有沒有該數(shù)據(jù)find = false;for(j = 0;j M;汁+)if( Blockj = Datai)find = tr
9、ue;if( find ) continue; /塊中有該數(shù)據(jù),判斷下一個(gè)數(shù)據(jù)/塊中沒有該數(shù)據(jù),最優(yōu)算法ChangeTimes+; / 缺頁(yè)次數(shù)+for(j = 0;j M;j+)/找到下一個(gè)值的位ffind = false;for( k = i;k M )/獲得要替換的塊指針temp = 0;for(j = 0;j v M;j+)if( temp countj)temp = countj;point = j; /獲得離的最遠(yuǎn)的指針else point = i;/替換Blockpoint = Datai;/保存要顯示的數(shù)據(jù) for(j = 0;j v M;j+)DataShowji = Blo
10、ckj;DataShowEnablei M ? (j n);DataOutputQ;/先進(jìn)先岀置換算法void FIFO()int i,j;bool find;int point;int temp; /臨時(shí)變量int m = l,n;ChangeTimes = 0;for(j = 0;j v M;j+)for(i = 0;i v N;i+)DataShowEnableji = false; / 初始化為 false,表示沒有要顯示的數(shù)據(jù)for(i = 0;i =3的塊,替換后計(jì)數(shù)值置1,/同時(shí)其它的塊計(jì)數(shù)值加1 ,成了(13 2),見下面先進(jìn)先出程序段/確定當(dāng)前頁(yè)面是否在物理塊中,在繼續(xù),不在
11、置換/ /Block0 = DataO;for(i = l;m M;i+)int flag = 1;for(n = 0; n m;n+)if(Datai = Blockn) flag = 0;if (flag = 0) continue;Blockm = Datai;m+;/ /對(duì)有所數(shù)據(jù)操作for(i = 0;i v N;i+)/ 增加 countfor(j = 0;j v M;j+)countj+;find = false; /表示塊中有沒有該數(shù)據(jù)for(j = 0;j M )/獲得要替換的塊指針temp = 0;for(j = 0;j v M;j+)if( temp countj)tem
12、p = countj;point = j; /獲得離的最遠(yuǎn)的指針else point = i;/替換Blockpoint = Datai;countpoint = 0; / 更新計(jì)數(shù)值/保存要顯示的數(shù)據(jù)for(j = 0;j M;j+)DataShowji = Blockj;DataShowEnablei M ? (j nu); DataOutputQ;/最近最久未使用置換算法void LRU()int i,j;bool find;int point;int temp; /臨時(shí)變量int m = l,n;ChangeTimes = 0;for(j = 0;j M;j+)for(i = 0;i
13、N;i+)DataShowEnableji = false; / 初始化為 false, 表示沒有要顯示的數(shù)據(jù)for(i = 0;i M;i+)counti = 0 ; /初始化計(jì)數(shù)器/確定當(dāng)前頁(yè)面是否在物理塊中,在繼續(xù),不在置換/Block0 = DataO;for(i = l;m M;i+)int flag = 1;for(n = 0; n m;n+)if(Datai = Blockn) flag = 0;if (flag = 0) continue;Blockm = Datai;m+;/對(duì)有所數(shù)據(jù)操作for(i = 0;i v N;i+)/ 增加 countfor(j = 0;j M;汁
14、+)countj+;find = false; /表示塊中有沒有該數(shù)據(jù)for(j = 0;j M )/獲得要替換的塊指針temp = 0;for(j = 0;j v M;j+)if( temp countj)temp = countj;point = j; /獲得離的最遠(yuǎn)的指針else point = i;/替換Blockpoint = Datai; countpoint = 0;/保存要顯示的數(shù)據(jù)for(j=0;jM;j+)DataShowji = Blockj;DataShowEnablei M ?(j nM);DataOutput();實(shí)驗(yàn)結(jié)果截圖:程序運(yùn)行:輸入相應(yīng)數(shù)據(jù):數(shù)冋列2 蓊詢序4 理面間 frli亠U貝 AJ入擇入輸 土冃青青青 I It 11:320序列的方式隨機(jī)2 輸入;2:選擇相應(yīng)算法:最佳置換算法:先進(jìn)先出算法:fo =0 12 02n142303212017014440007773222111UUR03332221欽:12 :60 7.系單選擇* *XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX1- Optimal*2- FIFO*3- LRU*0
溫馨提示
- 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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025年度二手車寄售代理服務(wù)合同
- 2025年度吊車租賃與施工現(xiàn)場(chǎng)管理服務(wù)協(xié)議
- 2025年車貸居間服務(wù)收費(fèi)標(biāo)準(zhǔn)合同范本
- 建立適應(yīng)性強(qiáng)的財(cái)務(wù)體系計(jì)劃
- 學(xué)生領(lǐng)導(dǎo)力培養(yǎng)課程計(jì)劃
- 教學(xué)工作創(chuàng)新方向計(jì)劃
- 年度戰(zhàn)略性談判的技巧分享計(jì)劃
- 市場(chǎng)調(diào)研與分析工作安排計(jì)劃
- 特色課程開發(fā)與實(shí)施方案計(jì)劃
- 高危作業(yè)的安全保障措施優(yōu)化計(jì)劃
- 物流托運(yùn)單模板
- CNC設(shè)備具體參數(shù)
- 濕式石灰石法煙氣脫硫的工藝流程
- 7S目視化管理標(biāo)準(zhǔn)
- 酒店成本管理系統(tǒng)PICC
- 文科學(xué)術(shù)規(guī)范與學(xué)術(shù)論文寫作課件
- 人教版小學(xué)二年級(jí)體育下冊(cè)全冊(cè)教案
- 【員工關(guān)系管理研究國(guó)內(nèi)外文獻(xiàn)綜述2800字】
- 電動(dòng)機(jī)潤(rùn)滑檔案
- 聯(lián)通光纜及傳輸網(wǎng)絡(luò)搶修應(yīng)急預(yù)案
- 《發(fā)展?jié)h語(yǔ)(第二版)中級(jí)綜合(Ⅰ)》第7課+課件
評(píng)論
0/150
提交評(píng)論