下載本文檔
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
實(shí)驗(yàn)11內(nèi)存塊的申請(qǐng)與釋放實(shí)驗(yàn)?zāi)康恼莆諆?nèi)存動(dòng)態(tài)分區(qū)的實(shí)現(xiàn)方法。進(jìn)一步掌握內(nèi)存塊的分配策略。掌握內(nèi)存塊申請(qǐng)與釋放的算法與實(shí)現(xiàn)。實(shí)驗(yàn)內(nèi)容寫一個(gè)程序,模擬實(shí)現(xiàn)內(nèi)存的動(dòng)態(tài)分區(qū)分配算法。假設(shè)內(nèi)存大小為100K。分別使用首次適應(yīng)算法、最佳適應(yīng)算法分配內(nèi)存空間。實(shí)現(xiàn)對(duì)內(nèi)存空間的釋放。顯示內(nèi)存分配情況。實(shí)驗(yàn)環(huán)境本實(shí)驗(yàn)可以在TurboC環(huán)境卜實(shí)現(xiàn),也可以使Lmux系統(tǒng)的gcc實(shí)現(xiàn)。實(shí)驗(yàn)程序及分析/, 進(jìn)入程序后可以根據(jù)菜單項(xiàng)進(jìn)入不同的模塊/* 1.使用首次適應(yīng)算法分配空間/* 2.使用最佳適應(yīng)算法分配空間/* 3. 釋放一塊空間/* 4. 顯示內(nèi)存分配情況/* 5. 退出系統(tǒng)^include<stdio.h>^include<stdlib?h>^include<conio.h>^include<string?h>ftdefineMEMSIZE100 /*定義內(nèi)存大小為100*/ftdefineMINSIZE2 /*分配時(shí)如果剩余值小于此值則不再分割?/rypedefstruct_MemoryInformation{/*空l'可分區(qū)表結(jié)構(gòu)★/intstart; /*起始地址"intsize; /*大小*/charinfo; /,狀態(tài):,廣空閑(FREE):,"占用(USED);W表結(jié)束(END)*/}MEMINFO;MEMINFOMemList[MEMSIZE];voidDisplay();/,函數(shù)名:InitAll()/★功能:初始化所有變量。/* voidInitAll()(inti;MEMINFOtemp=(0,0z'};for(i=0;i<MEMSIZE;i++)MemList[i]=temp;MemList[0].start=0;MemList[0].size=MEMSIZE;MemList[0].info=1f';}/* /*函數(shù)名:FirstFit_new()/?功能:使用首次最算法分配內(nèi)存voidFirstFit_new()(inti,j,size;chartemp[10];printf("HowmanyMEMORYrequir?");gets(temp);size=atoi(temp);for(i=0;i<MEMSIZE-l&&MemListfi].info!='e*;i++)(if(MemList[i].size>=size&&MemList[i].info==1f')(if(MemList[i].size-size<=MINSIZE)MemLis,c[i].info='u*;else(for(j=MEMSIZE-2;j>i;j—){MemList[j+1]=MemList[j];}MemLisr[i+1].start=MemList[i].start+size;MemList[i+1].size=MemList[i].size-size;MemList[i+1]?info='f1;MemLisr[i].size=size;MemLisrti].info=,u';}break;}}if(i==MEMSIZE-l||MemList[i].info==*e')(printf("NOTEnoughMemory!!\nn);getch();}Display();}/* /★函數(shù)名:BestFit_new()/?功能:使用最佳盡應(yīng)算法分配內(nèi)存/* voidBestFit_new()(intizjrflag,size;chartemp[10];prinrf(HHowmanyMEMORYrequir?");gets(temp);size=atoi(temp);j=0;flag=0;k=MEMSIZE;for(i=0;i<MEMSIZE-l&&MemList[i].info!=*e';i++)(if(MemList[i].size>=size&&MemList[i].info=='f')(flag=l;if(MemList[i].size<k)(k=MemList[i].size;j=i;}}}??if(flag==0)(printf("NOTEnoughMemory!!\nn);getch();}elseif(MemList[i].size-size<=MINSIZE)MemList[i].info='u';else(for(j=MEMSIZE-2;j>i;j--)(MemList[j+1]=MemList[j];}MemList[i+1].s,car'C=MemLi3t[i].start+size;MemList[i+1].size=MemList[i].size-size;MemList[i+1].info='f';MemList[i].size=size;MemList[i].info='u';}Display();}/* /,函數(shù)名:del()/?功能:釋放一塊內(nèi)存voiddel(){inti,number;chartemp[10];printf("PleaseInupttheNUMERyouwanttostop:");gets(temp);number=a*toi(temp);if(MemList[number].info=='u')(MemList[number].info=1f';if(MemList[number+1].info=='f')(MemList[number].size+=MemLisr[number+1].size;for(i=number+l;i<MEMSIZE-l&&MemList[i].info!='e,;i++)MemLisr[i]=MemList[i+1];}if(MemList[number-1].info=='f')(MemList[number-1].size+=MemList[number].size;for(i=number;i<MEMSIZE-l&&MemList[i].info!=,e';i++)MemList[i]=MemList[i+1];}}else(printf("ThisNumberisNOTexistorisNOTused!\nH);getch();}Display();}TOC\o"1-5"\h\z/* *//,函數(shù)名:Display() *//★功能:顯示內(nèi)存狀態(tài) ?//* */voidDisplay()(intizused=0;clrscr();printf(H\n \nH);printf(H%5s%15s%15s%15s\n'\HNumberHz“Star匚",“Size","Info”);printf(" \nH);for(i=0;i<MEMSIZE&&MemList[i].info!='e';i++)(if(MemList[i].info=='u1)used+=MemList[i].size;prinrf(H%5d%15d%15d%15s\n",i,MemList[i].srart,MemList[i].size,MemList[i].info=='u'?"USEDn:"FREE");}printf(" \nH)rprintf(" Total Size:%~10d Used:%-10dFree:%-10d\n",MEMSIZE,used,MEMSIZE-used);printf(H\n\nPressAnyKeytoReturn...\nn);getch();/* /★函數(shù)名:Main()/,功能:主函數(shù)/* main()(charch;InitAll();while(1)(clrscr();printf(" MemoryManager\nH);printf(H=========================================================\nn),printf(" 1. GetablockusetheFIRSTFITmethod \nn);printf(" 2. GetablockusetheBESTFITmethod \n");printf(" 3. Freeablock\n");printf(" 4. DisplayMeminfomation\nM);printf(" 5.Exit\nH);printf("=====================================
溫馨提示
- 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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 新疆維吾爾自治區(qū)烏魯木齊市米東區(qū)三校聯(lián)考 2024-2025學(xué)年 高二上學(xué)期期末考試 化學(xué)試題(含答案)
- 陜西省漢中市寧強(qiáng)縣2024-2025學(xué)年八年級(jí)上學(xué)期1月期末考試生物試卷(含答案)
- 年產(chǎn)1萬噸全谷物(蒸谷米)深加工項(xiàng)目可行性研究報(bào)告寫作模板-申批備案
- 安徽省安慶市懷寧縣2024-2025學(xué)年高二上學(xué)期1月期末考試化學(xué)試題(含答案)
- 化學(xué)-山東省濰坊市、臨沂市2024-2025學(xué)年度2025屆高三上學(xué)期期末質(zhì)量檢測試題和答案
- 2025年度卓爾系智慧城市建設(shè)合作協(xié)議3篇
- 2025年度出租車承包運(yùn)營服務(wù)質(zhì)量評(píng)價(jià)合同3篇
- 2024牙科醫(yī)療信息管理系統(tǒng)合同
- 2024高端制造設(shè)備進(jìn)口合同
- 2024水利水電工程施工合同范本
- 陸上風(fēng)電場設(shè)備選型技術(shù)導(dǎo)則
- 核心素養(yǎng)導(dǎo)向的單元整體教學(xué)
- 中醫(yī)婦科疾病的治療(完美版)課件
- 汽車維修行業(yè)投訴處理管理制度
- 物業(yè)客服服務(wù)技巧培訓(xùn)
- 山東省青島市2024-2025學(xué)年七年級(jí)上學(xué)期11月期中英語試題
- 2024年海南省公務(wù)員錄用考試《行測》試題及答案解析
- 招聘技巧的培訓(xùn)
- 北師大版一年級(jí)上冊數(shù)學(xué)全冊教案(教學(xué)設(shè)計(jì))及教學(xué)反思
- 教育機(jī)構(gòu)日常運(yùn)營與管理指南
- 海上移動(dòng)平臺(tái)入級(jí)規(guī)范2024年第1次變更通告
評(píng)論
0/150
提交評(píng)論