![大二下操作系統(tǒng)實(shí)驗(yàn)八內(nèi)存分配與回收算法實(shí)現(xiàn)_第1頁](http://file4.renrendoc.com/view/35f1fcd62a60d153ff09dbf65647d0a5/35f1fcd62a60d153ff09dbf65647d0a51.gif)
![大二下操作系統(tǒng)實(shí)驗(yàn)八內(nèi)存分配與回收算法實(shí)現(xiàn)_第2頁](http://file4.renrendoc.com/view/35f1fcd62a60d153ff09dbf65647d0a5/35f1fcd62a60d153ff09dbf65647d0a52.gif)
![大二下操作系統(tǒng)實(shí)驗(yàn)八內(nèi)存分配與回收算法實(shí)現(xiàn)_第3頁](http://file4.renrendoc.com/view/35f1fcd62a60d153ff09dbf65647d0a5/35f1fcd62a60d153ff09dbf65647d0a53.gif)
![大二下操作系統(tǒng)實(shí)驗(yàn)八內(nèi)存分配與回收算法實(shí)現(xiàn)_第4頁](http://file4.renrendoc.com/view/35f1fcd62a60d153ff09dbf65647d0a5/35f1fcd62a60d153ff09dbf65647d0a54.gif)
![大二下操作系統(tǒng)實(shí)驗(yàn)八內(nèi)存分配與回收算法實(shí)現(xiàn)_第5頁](http://file4.renrendoc.com/view/35f1fcd62a60d153ff09dbf65647d0a5/35f1fcd62a60d153ff09dbf65647d0a55.gif)
下載本文檔
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
實(shí)驗(yàn)八內(nèi)存分配與回收算法實(shí)現(xiàn)
1、實(shí)驗(yàn)?zāi)康?/p>
掌握為實(shí)現(xiàn)多道程序并發(fā)執(zhí)行,操作系統(tǒng)是如何通過作業(yè)調(diào)度選擇作業(yè)進(jìn)入內(nèi)存
系統(tǒng)如何為進(jìn)入內(nèi)存的作業(yè)分配內(nèi)存空間,實(shí)現(xiàn)多道作業(yè)同時(shí)駐留內(nèi)存,就緒進(jìn)程隊(duì)列中的多個(gè)進(jìn)程是如何以分式方式共享CPU,作業(yè)運(yùn)行完成離開系統(tǒng)時(shí),系統(tǒng)如何進(jìn)行內(nèi)存回收,計(jì)算進(jìn)程周轉(zhuǎn)時(shí)間。
掌握各種調(diào)度算法,以及實(shí)現(xiàn)所需的各種數(shù)據(jù)結(jié)構(gòu)。
2、實(shí)驗(yàn)內(nèi)容
根據(jù)給定的動(dòng)態(tài)分區(qū)分配算法流程圖(p112,圖4-10),用你熟悉的計(jì)算機(jī)編程語言編寫一程序,該程序?qū)崿F(xiàn)內(nèi)存的合理分配后回收。
#include<stdio.h>#include<stdlib.h>#include<cstring>#include<cstdlib>#defineM10
//************************空閑內(nèi)存結(jié)構(gòu)體typedefstruct
{
intstartaddress;intendaddress;charname[20];intsize;
intstate;
}area;
//****************作業(yè)記錄結(jié)構(gòu)體typedefstruct
{
charpname[20];intpsize;
}progress;intN=10;intk=0;
//*****************空閑內(nèi)存結(jié)構(gòu)體初始化voidinit(area*f)
{
f[0].startaddress=0;f[0].endaddress=400;f[0].size=400;f[0].state=0;strcpy(f[0].name,"null");
k++;
}
//******************分配內(nèi)存
voidinsert( area*f,inti,intb,intc)
{
intj;for(j=k;j>i;j--)
f[j]=f[j-1];f[i].startaddress=b;f[i].endaddress=c;f[i].state=0;
f[i].size=c-b;strcpy(f[i].name,"null");k++;
}
voidapplication( area*f,progressp)
{
inti,ff=0;for(i=0;i<k;i++)
if(!f[i].state)
{
if(f[i].size<p.psize)continue;
elseif(f[i].size==p.psize)
{
strcpy(f[i].name,p.pname);f[i].state=1;
ff=1;break;
}
else
{
insert(f,i+1,f[i].startaddress+p.psize,f[i].endaddress);f[i].endaddress=f[i].startaddress+p.psize-1;f[i].size=p.psize;
f[i].state=1;strcpy(f[i].name,p.pname);ff=1;
break;
}
}
if(ff)
printf(" 申請成功\n");
else
printf("申請失敗,對不起,主內(nèi)存的空閑表中沒有足夠的內(nèi)存!\n");
}
//*****************輸出結(jié)果voidprint( area*f)
{
intj;printf("************************************************************\n");printf("* 進(jìn)程號進(jìn)程名 始址 結(jié)束地址 大小 狀態(tài) *\n\n");for(j=0;j<k;j++)
printf("* %d%10s%10d%10d%11d%7d
*\n",j,f[j].name,f[j].startaddress,f[j].endaddress,f[j].size,f[j].state);printf("************************************************************\n\n");}
//******************回收內(nèi)存voidrecovery( area*f,inti)
{
intj,ff=1;if((i+1)<k&&f[i+1].state==0)
{
f[i].endaddress=f[i+1].endaddress;strcpy(f[i].name,"null");
f[i].size+=f[i+1].size;f[i].state=0;for(j=i+1;j<k-1;j++)f[j]=f[j+1];
if(k>1)
{
k--;
return;
}
recovery(f,i+1);
ff=0;return;
}
if((i-1)>=0&&f[i-1].state==0)
{
f[i-1].endaddress=f[i].endaddress;strcpy(f[i-1].name,"null");
f[i-1].size+=f[i].size;
for(j=i;j<k-1;j++)f[j]=f[j+1];if(k>1)
{
k--;
return;
}
recovery(f,i-1);
ff=0;return;
}
if(ff)
{
strcpy(f[i].name,"null");f[i].state=0;
}
}
//************主函數(shù)voidmain()
{
intss=1,i,j=0;areaf[M];
progressp[M];
printf(" ************內(nèi)存分配與回收*************\n\n");init(f);
while(ss)
{
printf("請選擇操作項(xiàng):\n");printf("1.內(nèi)存分配\n");
printf("2.內(nèi)存回收\n");
printf("0.退出操作\n");
printf("選項(xiàng):");
scanf("%d",&i);
printf("\n");switch(i)
{
case1:
printf("請輸入作業(yè)名稱,大?。篭n");printf("進(jìn)程名: \n");
scanf("%s",p[j].pname);printf("進(jìn)程大小:");scanf("%d",&p[j].psize);
application(f,p[j]);
j++;
print(f);break;
case2:
printf("你要回收的表序號(0---%d):",k-1);scanf("%d",&i);
if((i<0)||(i>k-1))
printf("輸入錯(cuò)誤,沒有該進(jìn)程\n\n");
else
{ recovery(f,i);
printf(" 回收成功\n");
print(f);
}
break;case0:
ss=0;b
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 學(xué)校教室翻新承包合同
- 水上養(yǎng)殖沙石運(yùn)輸合同范本
- 家禽飼料緊急配送服務(wù)協(xié)議
- 服裝輔料物流配送合同
- 休閑度假村改造合同
- 液體消毒劑運(yùn)輸協(xié)議
- 寵物市場租賃合同
- 倉儲裝修管理協(xié)議
- 鷹潭鋼結(jié)構(gòu)樓梯施工方案
- 生態(tài)綠化工地施工方案
- 前列腺癌診斷治療指南
- 機(jī)械加工生產(chǎn)計(jì)劃排程表
- 女性生殖系統(tǒng)解剖與生理 生殖系統(tǒng)的血管淋巴和神經(jīng)
- 江蘇省2023年對口單招英語試卷及答案
- 易制毒化學(xué)品安全管理制度匯編
- GB/T 35506-2017三氟乙酸乙酯(ETFA)
- GB/T 25784-20102,4,6-三硝基苯酚(苦味酸)
- 特種設(shè)備安全監(jiān)察指令書填寫規(guī)范(特種設(shè)備安全法)參考范本
- 硬筆書法全冊教案共20課時(shí)
- 《長方形的面積》-完整版課件
- PDCA降低I類切口感染發(fā)生率
評論
0/150
提交評論