頁面置換算法模擬——OPTFIFO和LRU算法_第1頁
頁面置換算法模擬——OPTFIFO和LRU算法_第2頁
頁面置換算法模擬——OPTFIFO和LRU算法_第3頁
頁面置換算法模擬——OPTFIFO和LRU算法_第4頁
頁面置換算法模擬——OPTFIFO和LRU算法_第5頁
已閱讀5頁,還剩11頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(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ì)自己和他人造成任何形式的傷害或損失。

評(píng)論

0/150

提交評(píng)論