




已閱讀5頁(yè),還剩11頁(yè)未讀, 繼續(xù)免費(fèi)閱讀
版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
存儲(chǔ)管理實(shí)驗(yàn)實(shí)驗(yàn)報(bào)告1實(shí)驗(yàn)?zāi)康脑O(shè)計(jì)一個(gè)固定分區(qū)分配的存儲(chǔ)管理方案,并編程模擬實(shí)現(xiàn)分區(qū)的分配和回收過(guò)程。 對(duì)分區(qū)的管理法可以是循環(huán)首次適應(yīng)算法 或 最佳適應(yīng)算法。2實(shí)驗(yàn)原理通過(guò)采用最佳適應(yīng)算法的固定式分區(qū)分配的存儲(chǔ)管理方案,模擬實(shí)現(xiàn)分區(qū)的分配和回收過(guò)程??梢约俣總€(gè)作業(yè)都是批處理作業(yè),并且不允許動(dòng)態(tài)申請(qǐng)內(nèi)存。為實(shí)現(xiàn)分區(qū)的分配和回收,可以設(shè)定一個(gè)分區(qū)說(shuō)明表,按照表中的有關(guān)信息進(jìn)行分配,并根據(jù)分區(qū)的分配和回收情況修改該表。3采用算法及算法描述本程序通過(guò)手動(dòng)輸入內(nèi)存大小的輸入,然后通過(guò)冒泡法對(duì)分區(qū)的大小進(jìn)行排序,采用最佳適應(yīng)算法構(gòu)建整個(gè)算法的架構(gòu),該算法要求所有的空閑分區(qū)按照其容量的大小進(jìn)行從小到大的順序形成一空閑分區(qū)鏈。因而,第一次如果能夠滿足要求的空閑區(qū),必然是最佳的。該算法也存在一定的缺陷,因?yàn)槊看畏峙浜笄懈钕聛?lái)的剩余部分總是最小的,故而存儲(chǔ)器中會(huì)留下許多難以利用的小空余區(qū)。4數(shù)據(jù)結(jié)構(gòu)描述,程序模塊劃分頭文件模塊:#include stdio.h#include windows.h#include #include #define PCB_NUM 5 /模擬進(jìn)程數(shù)量 #define INT 800/內(nèi)存分區(qū)數(shù)量 struct MemInfint addr; /分區(qū)起始地址 int size; /分區(qū)大小int state; /0表示空閑,0時(shí)表示已分配,存儲(chǔ)的是進(jìn)程ID ; struct PCB int pcbID; /進(jìn)程ID int size; /進(jìn)程大小 int RunState; /運(yùn)行狀態(tài),0表示就緒,1表示已分配內(nèi)存正運(yùn)行,2表示運(yùn)行結(jié)束且退出內(nèi)存 int TolTime; /總需要運(yùn)行時(shí)間 int RunTime; /已運(yùn)行時(shí)間 ; PCB pcbListPCB_NUM;菜單模塊:void menu() /菜單 int m;system(cls);printf(nntt*ttn);printf(tttt固定分區(qū)存儲(chǔ)程序演示n);printf(tt*ttn);printf(nttt1.執(zhí)行程序.);printf(nttt0.退出程序.);scanf(%d,&m);switch(m)case 1: break;case 0: system(cls);menu(); break;default: system(cls);break;排序模塊:void paixu(struct MemInf* ComMem,int n) int i,j,t; for(j=0;jn-1;j+) for(i=0;iComMemi+1.size) t=ComMemi.size; ComMemi.size=ComMemi+1.size; ComMemi+1.size=t; void paixu2() int i,j,t; for(j=0;j4;j+) for(i=0;ipcbListi+1.size) t=pcbListi.size; pcbListi.size=pcbListi+1.size; pcbListi+1.size=t; 主函數(shù)模塊:void main()DD: menu();char ch;int i,j,n,a=0;struct MemInf* ComMem; system(cls); printf(你要分多少個(gè)分區(qū)呢,請(qǐng)輸入數(shù)值吧:); /個(gè)分區(qū)大小的輸入 scanf(%d,&n); ComMem=(struct MemInf*)malloc(n*sizeof(struct MemInf); printf(請(qǐng)劃分內(nèi)存固定大小分區(qū):n);/劃分內(nèi)存固定大小分區(qū) for(i=0;i=INT) printf(超出規(guī)定內(nèi)存范圍); ch=getchar(); ch=getchar(); goto DD; paixu(ComMem,n);/初始化就緒進(jìn)程隊(duì)列pcbList0.pcbID =1;pcbList0.RunState =0; /運(yùn)行狀態(tài),0表示就緒,1表示已分配內(nèi)存正運(yùn)行,2表示運(yùn)行結(jié)束且退出內(nèi)存 pcbList0.size=30;pcbList0.RunTime =0; pcbList0.TolTime =5;pcbList1.pcbID =2;pcbList1.RunState =0;pcbList1.size=15;pcbList1.RunTime =0;pcbList1.TolTime =6;pcbList2.pcbID =3;pcbList2.RunState =0;pcbList2.size=50;pcbList2.RunTime =0;pcbList2.TolTime =3;pcbList3.pcbID =4;pcbList3.RunState =0;pcbList3.size=120;pcbList3.RunTime =0;pcbList3.TolTime =4; pcbList4.pcbID =5;pcbList4.RunState =0;pcbList4.size=125;pcbList4.RunTime =0;pcbList4.TolTime =9;ch=getchar();ch=getchar();while(pcbListPCB_NUM-1.RunTime pcbListPCB_NUM-1.TolTime)for(j=0;jPCB_NUM;j+)/內(nèi)存分配for(i=0;i= pcbListj.size) /如果該內(nèi)存分區(qū)空間大于或等于進(jìn)程空間,即可以把該空閑內(nèi)存分區(qū)分配給該進(jìn)程 ComMemi.state =pcbListj.pcbID ;pcbListj.RunState=1;/內(nèi)存回收if(pcbListj.RunTime =pcbListj.TolTime) /如果該進(jìn)程運(yùn)行時(shí)間大于或等于總需時(shí)間,即可回收該進(jìn)程占用內(nèi)存 for(i=0;in;i+)if(ComMemi.state = pcbListj.pcbID) ComMemi.state = 0; /內(nèi)存狀態(tài)變?yōu)?未分配pcbListj.RunState=2; /進(jìn)程狀態(tài)變?yōu)?運(yùn)行完畢 /運(yùn)行時(shí)間加1for(i=0;iPCB_NUM;i+)if (pcbListi.RunState=1 & pcbListi.RunTime pcbListi.TolTime) /處于運(yùn)行狀態(tài)且運(yùn)行時(shí)間小于總需時(shí)間的進(jìn)程,運(yùn)行時(shí)間加1 pcbListi.RunTime+; 顯示模塊:printf(進(jìn)程IDt 進(jìn)程大小t 狀態(tài)t 需要時(shí)間t 運(yùn)行時(shí)間n);for(i=0;iPCB_NUM;i+)printf(%dt %dtt %dt %dtt %dn,pcbListi.pcbID,pcbListi.size, pcbListi.RunState, pcbListi.TolTime ,pcbListi.RunTime);printf(分區(qū)IDt 分區(qū)大小t 狀態(tài)n);for(i=0;in;i+)printf(%dt %dtt %dn,i,ComMemi.size ,ComMemi.state );printf(按回車鍵繼續(xù).n); getchar(); /按任意鍵繼續(xù)(分步執(zhí)行,以便觀察內(nèi)存分配回收)5主模塊流程圖、各子模塊流程圖6程序源代碼及調(diào)試#include stdio.h#include windows.h#include #include #define PCB_NUM 5 /模擬進(jìn)程數(shù)量 #define INT 800/內(nèi)存分區(qū)數(shù)量 struct MemInfint addr; /分區(qū)起始地址 int size; /分區(qū)大小int state; /0表示空閑,0時(shí)表示已分配,存儲(chǔ)的是進(jìn)程ID ; struct PCB int pcbID; /進(jìn)程ID int size; /進(jìn)程大小 int RunState; /運(yùn)行狀態(tài),0表示就緒,1表示已分配內(nèi)存正運(yùn)行,2表示運(yùn)行結(jié)束且退出內(nèi)存 int TolTime; /總需要運(yùn)行時(shí)間 int RunTime; /已運(yùn)行時(shí)間 ; PCB pcbListPCB_NUM;void menu() /菜單 int m;system(cls);printf(nntt*ttn);printf(tttt固定分區(qū)存儲(chǔ)程序演示n);printf(tt*ttn);printf(nttt1.執(zhí)行程序.);printf(nttt0.退出程序.);scanf(%d,&m);switch(m)case 1: break;case 0: system(cls);menu(); break;default: system(cls);break;void paixu(struct MemInf* ComMem,int n) int i,j,t; for(j=0;jn-1;j+) for(i=0;iComMemi+1.size) t=ComMemi.size; ComMemi.size=ComMemi+1.size; ComMemi+1.size=t; void paixu2() int i,j,t; for(j=0;j4;j+) for(i=0;ipcbListi+1.size) t=pcbListi.size; pcbListi.size=pcbListi+1.size; pcbListi+1.size=t; void main()DD: menu();char ch;int i,j,n,a=0;struct MemInf* ComMem; system(cls); printf(你要分多少個(gè)分區(qū)呢,請(qǐng)輸入數(shù)值吧:); scanf(%d,&n); ComMem=(struct MemInf*)malloc(n*sizeof(struct MemInf); printf(請(qǐng)劃分內(nèi)存固定大小分區(qū):n);/劃分內(nèi)存固定大小分區(qū) for(i=0;i=INT) printf(超出規(guī)定內(nèi)存范圍); ch=getchar(); ch=getchar(); goto DD; paixu(ComMem,n);/初始化就緒進(jìn)程隊(duì)列pcbList0.pcbID =1;pcbList0.RunState =0; /運(yùn)行狀態(tài),0表示就緒,1表示已分配內(nèi)存正運(yùn)行,2表示運(yùn)行結(jié)束且退出內(nèi)存 pcbList0.size=30;pcbList0.RunTime =0; pcbList0.TolTime =5;pcbList1.pcbID =2;pcbList1.RunState =0;pcbList1.size=15;pcbList1.RunTime =0;pcbList1.TolTime =6;pcbList2.pcbID =3;pcbList2.RunState =0;pcbList2.size=50;pcbList2.RunTime =0;pcbList2.TolTime =3;pcbList3.pcbID =4;pcbList3.RunState =0;pcbList3.size=120;pcbList3.RunTime =0;pcbList3.TolTime =4; pcbList4.pcbID =5;pcbList4.RunState =0;pcbList4.size=125;pcbList4.RunTime =0;pcbList4.TolTime =9;ch=getchar();ch=getchar();while(pcbListPCB_NUM-1.RunTime pcbListPCB_NUM-1.TolTime)for(j=0;jPCB_NUM;j+)/內(nèi)存分配for(i=0;i= pcbListj.size) /如果該內(nèi)存分區(qū)空間大于或等于進(jìn)程空間,即可以把該空閑內(nèi)存分區(qū)分配給該進(jìn)程 ComMemi.state =pcbListj.pcbID ;pcbListj.RunState=1;/內(nèi)存回收if(pcbListj.RunTime =pcbListj.TolTime) /如果該進(jìn)程運(yùn)行時(shí)間大于或等于總需時(shí)間,即可回收該進(jìn)程占用內(nèi)存 for(i=0;in;i+)if(ComMemi.state = pcbListj.pcbID) ComMemi.state = 0; /內(nèi)存狀態(tài)變?yōu)?未分配pcbListj.RunState=2; /進(jìn)程狀態(tài)變?yōu)?運(yùn)行完畢 /運(yùn)行時(shí)間加1for(i=0;iPCB_NUM;i+)if (pcbListi.RunState=1 & pcbListi.RunTime pcbListi.TolTime) /處于運(yùn)行狀態(tài)且運(yùn)行時(shí)間小于總需時(shí)間的進(jìn)程,運(yùn)行時(shí)間加1 pcbListi.RunTime+; /顯示模塊printf(進(jìn)程IDt 進(jìn)程大小t 狀態(tài)t 需要時(shí)間t 運(yùn)行時(shí)間n);for(i=0;iPCB_NUM;i+)printf(%dt %dtt %dt %dtt %dn,pcbListi.pcbID,pcbListi.size, pcbListi.RunState, pcbListi.TolTime ,pcbListi.RunTime)
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝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ù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 業(yè)務(wù)委托合同范例
- 兒子購(gòu)車合同范例
- 儀器報(bào)價(jià)合同范例
- 農(nóng)業(yè)股東協(xié)議 合同范例
- 促銷勞動(dòng)合同范例
- 倉(cāng)庫(kù)裝修施工合同范例
- ppp項(xiàng)目合同范例實(shí)例
- 關(guān)于農(nóng)資購(gòu)銷合同范例
- 價(jià)格框架協(xié)議合同范例
- 企業(yè)技術(shù)人員 合同范例
- 《危險(xiǎn)化學(xué)品企業(yè)安全生產(chǎn)標(biāo)準(zhǔn)化規(guī)范》專業(yè)深度解讀與應(yīng)用培訓(xùn)指導(dǎo)材料之5:5管理要求-5.5 安全風(fēng)險(xiǎn)管理和雙重預(yù)防機(jī)制建設(shè)(雷澤佳編制-2025A0)
- 2025年二級(jí)注冊(cè)建筑師《建筑經(jīng)濟(jì)、施工與設(shè)計(jì)業(yè)務(wù)管理》考試真題卷(附解析)
- 2025陜西煙草專賣局招聘42人易考易錯(cuò)模擬試題(共500題)試卷后附參考答案
- 礦山水災(zāi)事故處理
- 2024年煙臺(tái)棲霞市考選畢業(yè)生考試真題
- 2025北京九年級(jí)(上)期末語(yǔ)文匯編:現(xiàn)代文閱讀2
- 光譜分析在大氣污染物成分識(shí)別中的應(yīng)用研究
- 2025年高中生物學(xué)業(yè)水平考試知識(shí)點(diǎn)歸納總結(jié)(復(fù)習(xí)必背)
- 2025-2030中國(guó)晶圓轉(zhuǎn)移機(jī)器人末端執(zhí)行器行業(yè)市場(chǎng)發(fā)展趨勢(shì)與前景展望戰(zhàn)略研究報(bào)告
- 中外航海文化知到課后答案智慧樹章節(jié)測(cè)試答案2025年春中國(guó)人民解放軍海軍大連艦艇學(xué)院
- 湖南省炎德英才名校聯(lián)考聯(lián)合體2024年4月春季高一年級(jí)下學(xué)期第二次(期中)聯(lián)考數(shù)學(xué)試卷
評(píng)論
0/150
提交評(píng)論