




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、操作系統(tǒng)實(shí)驗(yàn)報(bào)告頁面置換算法模擬OFT、FIFO和LRU算法 班級(jí):2013級(jí)軟件工程1班 學(xué)號(hào):X X X 姓名:蕭氏一郎數(shù)據(jù)結(jié)構(gòu)說明:Memery10物理塊中的頁碼Page100頁面號(hào)引用串Temp10010輔助數(shù)組Void print(unsigned int t)輔助函數(shù)Viod FIFO()先進(jìn)先出頁面置換算法Viod LRU()最近最久未使用置換換算法Viod OPT()最佳置換算法流程圖:開始NONONOYesYesYes結(jié)束頁號(hào)序列載完?根據(jù)選擇的置換算法完成號(hào)存在物理塊中引用編號(hào)大于物理塊數(shù)將頁號(hào)放入物理地址中編號(hào)載入序列號(hào),從第0個(gè)得到頁號(hào) 源代碼:#include <
2、;stdio.h>#include <stdlib.h>/*全局變量*/int mSIZE; /*物理塊數(shù)*/int pSIZE; /*頁面號(hào)引用串個(gè)數(shù)*/static int memery10=0; /*物理塊中的頁號(hào)*/static int page100=0; /*頁面號(hào)引用串*/static int temp10010=0; /*輔助數(shù)組*/*置換算法函數(shù)*/void FIFO();void LRU();void OPT();/*輔助函數(shù)*/void print(unsigned int t);void designBy();void download();void
3、mDelay(unsigned int Delay);/*主函數(shù)*/void main() int i,k,code;printf("請(qǐng)輸入物理塊的個(gè)數(shù)(M<=10):");scanf("%d",&mSIZE);printf("請(qǐng)輸入頁面號(hào)引用串的個(gè)數(shù)(P<=100):");scanf("%d",&pSIZE);puts("請(qǐng)依次輸入頁面號(hào)引用串(連續(xù)輸入,無需隔開):");for(i=0;i<pSIZE;i+) scanf("%1d",&a
4、mp;pagei);download(); doputs("輸入的頁面號(hào)引用串為:");for(k=0;k<=(pSIZE-1)/20;k+)for(i=20*k;(i<pSIZE)&&(i<20*(k+1);i+)if(i+1)%20=0)|(i+1)%20)&&(i=pSIZE-1)printf("%dn",pagei);elseprintf("%d ",pagei);printf("* * * * * * * * * * * * * * * * * * * * * *
5、*n"); printf("* 請(qǐng)選擇頁面置換算法:ttt *n");printf("* - *n"); printf("* 1.先進(jìn)先出(FIFO) 2.最近最久未使用(LRU) *n");printf("* 3.最佳(OPT) 4.退出 *n");printf("* * * * * * * * * * * * * * * * * * * * * * *n"); printf("請(qǐng)選擇操作: bb"); scanf("%d",&code
6、); switch(code) case 1: FIFO(); break; case 2: LRU(); break; case 3: OPT(); break; case 4:system("cls");/system("color 0A"); exit(0);default:printf("輸入錯(cuò)誤,請(qǐng)重新輸入:"); printf("按任意鍵重新選擇置換算法:>>>");getch(); while (code!=4);getch();/*載入數(shù)據(jù)*/void download()prin
7、tf("nFinish.n載入成功!");/*設(shè)置延遲*/void mDelay(unsigned int Delay) unsigned int i; for(;Delay>0;Delay-)for(i=0;i<124;i+)printf(" b");/*顯示設(shè)計(jì)者信息*/void print(unsigned int t)int i,j,k,l;int flag;for(k=0;k<=(pSIZE-1)/20;k+)for(i=20*k;(i<pSIZE)&&(i<20*(k+1);i+)if(i+1)%
8、20=0)|(i+1)%20)&&(i=pSIZE-1)printf("%dn",pagei);elseprintf("%d ",pagei);for(j=0;j<mSIZE;j+)for(i=20*k;(i<mSIZE+20*k)&&(i<pSIZE);i+)if(i>=j)printf(" |%d|",tempij);elseprintf(" | |");for(i=mSIZE+20*k;(i<pSIZE)&&(i<20*(k+
9、1);i+)for(flag=0,l=0;l<mSIZE;l+)if(tempil=tempi-1l)flag+;if(flag=mSIZE)/*頁面在物理塊中*/printf(" ");elseprintf(" |%d|",tempij);/*每行顯示20個(gè)*/if(i%20=0)continue;printf("n");printf("-n");printf("缺頁次數(shù):%dtt",t+mSIZE);printf("缺頁率:%d/%dn",t+mSIZE,pSIZE
10、);printf("置換次數(shù):%dtt",t);printf("訪問命中率:%d%n",(pSIZE-(t+mSIZE)*100/pSIZE);printf("-n");/*計(jì)算過程延遲*/void compute()int i;printf("正在進(jìn)行相關(guān)計(jì)算,請(qǐng)稍候");for(i=0;i+<30;printf("b");for(i=0;i+<30;printf(" ");for(i=0;i+<30;printf("b");/*先進(jìn)先
11、出頁面置換算法*/void FIFO() int memery10=0; int time10=0; /*記錄進(jìn)入物理塊的時(shí)間*/ int i,j,k,m; int max=0; /*記錄換出頁*/ int count=0; /*記錄置換次數(shù)*/*前mSIZE個(gè)數(shù)直接放入*/ for(i=0;i<mSIZE;i+) memeryi=pagei; timei=i; for(j=0;j<mSIZE;j+)tempij=memeryj; for(i=mSIZE;i<pSIZE;i+) /*判斷新頁面號(hào)是否在物理塊中*/ for(j=0,k=0;j<mSIZE;j+) if(m
12、emeryj!=pagei) k+; if(k=mSIZE) /*如果不在物理塊中*/ count+;/*計(jì)算換出頁*/ max=time0<time1?0:1;for(m=2;m<mSIZE;m+)if(timem<timemax)max=m; memerymax=pagei; timemax=i; /*記錄該頁進(jìn)入物理塊的時(shí)間*/ for(j=0;j<mSIZE;j+)tempij=memeryj; else for(j=0;j<mSIZE;j+)tempij=memeryj; compute();print(count);/*最近最久未使用置換算法*/voi
13、d LRU() int memery10=0; int flag10=0; /*記錄頁面的訪問時(shí)間*/ int i,j,k,m; int max=0; /*記錄換出頁*/ int count=0; /*記錄置換次數(shù)*/*前mSIZE個(gè)數(shù)直接放入*/ for(i=0;i<mSIZE;i+) memeryi=pagei; flagi=i; for(j=0;j<mSIZE;j+)tempij=memeryj; for(i=mSIZE;i<pSIZE;i+) /*判斷新頁面號(hào)是否在物理塊中*/ for(j=0,k=0;j<mSIZE;j+) if(memeryj!=pagei)
14、 k+; elseflagj=i; /*刷新該頁的訪問時(shí)間*/ if(k=mSIZE) /*如果不在物理塊中*/ count+;/*計(jì)算換出頁*/ max=flag0<flag1?0:1;for(m=2;m<mSIZE;m+)if(flagm<flagmax)max=m; memerymax=pagei; flagmax=i; /*記錄該頁的訪問時(shí)間*/ for(j=0;j<mSIZE;j+)tempij=memeryj; else for(j=0;j<mSIZE;j+)tempij=memeryj; compute();print(count);/*最佳置換算法
15、*/void OPT() int memery10=0; int next10=0; /*記錄下一次訪問時(shí)間*/ int i,j,k,l,m; int max; /*記錄換出頁*/ int count=0; /*記錄置換次數(shù)*/*前mSIZE個(gè)數(shù)直接放入*/ for(i=0;i<mSIZE;i+) memeryi=pagei; for(j=0;j<mSIZE;j+)tempij=memeryj; for(i=mSIZE;i<pSIZE;i+) /*判斷新頁面號(hào)是否在物理塊中*/ for(j=0,k=0;j<mSIZE;j+) if(memeryj!=pagei) k+; if(k=mSIZE) /*如果不在物理塊中*/ count+;/*得到物理快中各頁下一次訪問時(shí)間*/for(m=0;m<mSIZE;m+)for(l=i+1;l<pSIZE;l+)if(memerym=pagel)br
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(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ī)械設(shè)備供貨承諾書范文
- 基于區(qū)塊鏈的公共文化服務(wù)供給信任機(jī)制研究-洞察闡釋
- 汽車行業(yè)技術(shù)服務(wù)保障措施的必要性
- 制造業(yè)生產(chǎn)成本分析與優(yōu)化范文
- 房地產(chǎn)開發(fā)中的政策組合效應(yīng)分析-洞察闡釋
- 初中地理學(xué)科探究學(xué)習(xí)計(jì)劃
- 環(huán)保設(shè)施年度隱患排查計(jì)劃
- 教育行業(yè)創(chuàng)新教學(xué)方法心得體會(huì)
- 醫(yī)療機(jī)構(gòu)物業(yè)管理的特殊要求與措施
- 小漫畫一則真的有蟲嗎300字15篇范文
- 醫(yī)療器械銷售流程與技巧
- 黑龍江省農(nóng)村信用社聯(lián)合社員工招聘考試真題2024
- 2025上海車展專題報(bào)告
- 紡織承包合同協(xié)議書
- 軟件轉(zhuǎn)讓合同協(xié)議書
- 2025年北京市豐臺(tái)區(qū)中考數(shù)學(xué)一模試卷
- 續(xù)簽采購(gòu)合同范本(標(biāo)準(zhǔn)版)
- 智能垃圾分類箱項(xiàng)目投資商業(yè)計(jì)劃書范本(投資融資分析)
- 2025至2030中國(guó)胸腺法新行業(yè)深度調(diào)查及投資前景研究報(bào)告
- 國(guó)有企業(yè)合同管理辦法3篇
- 2025-2030中國(guó)調(diào)光玻璃行業(yè)規(guī)模走勢(shì)及投資可行性分析研究報(bào)告
評(píng)論
0/150
提交評(píng)論