#include//全局變量floatminsize=5;intcount1=0;intcount2=0;#defineM10//假定系統(tǒng)允許的空閑區(qū)表最大">
最佳適應(yīng)算法 源程序代碼.doc

最佳適應(yīng)算法 源程序代碼.doc

ID:49977851

大小:22.40 KB

頁(yè)數(shù):6頁(yè)

時(shí)間:2020-03-03

最佳適應(yīng)算法 源程序代碼.doc_第1頁(yè)
最佳適應(yīng)算法 源程序代碼.doc_第2頁(yè)
最佳適應(yīng)算法 源程序代碼.doc_第3頁(yè)
最佳適應(yīng)算法 源程序代碼.doc_第4頁(yè)
最佳適應(yīng)算法 源程序代碼.doc_第5頁(yè)
資源描述:

《最佳適應(yīng)算法 源程序代碼.doc》由會(huì)員上傳分享,免費(fèi)在線閱讀,更多相關(guān)內(nèi)容在應(yīng)用文檔-天天文庫(kù)。

1、最佳適應(yīng)算法源程序代碼#include#include//全局變量floatminsize=5;intcount1=0;intcount2=0;#defineM10//假定系統(tǒng)允許的空閑區(qū)表最大為m#defineN10//假定系統(tǒng)允許的最大作業(yè)數(shù)量為n//已分配表的定義struct{floataddress;//已分分區(qū)起始地址floatlength;//已分分區(qū)長(zhǎng)度,單位為字節(jié)intflag;//已分配區(qū)表登記欄標(biāo)志,"0"表示空欄目}used_table[N];//

2、已分配區(qū)表對(duì)象名//空閑區(qū)表的定義:struct{floataddress;//空閑區(qū)起始地址floatlength;//空閑區(qū)長(zhǎng)度,單位為字節(jié)intflag;//空閑區(qū)表登記欄標(biāo)志,用"0"表示空欄目,用"1"表示未分配}free_table[M];//空閑區(qū)表對(duì)象名//函數(shù)聲明voidinitialize(void);intdistribute(int,float);intrecycle(int);voidshow();//初始化兩個(gè)表voidinitialize(void){inta;for(a=0;a<=N

3、-1;a++)used_table[a].flag=0;//已分配表的表項(xiàng)全部置為空表項(xiàng)free_table[0].address=1000;free_table[0].length=1024;free_table[0].flag=1;//空閑區(qū)表的表項(xiàng)全部為未分配}//最優(yōu)分配算法實(shí)現(xiàn)的動(dòng)態(tài)分區(qū)intdistribute(intprocess_name,floatneed_length){inti,k=-1;//k用于定位在空閑表中選擇的未分配欄floatads,len;intcount=0;i=0;while(

4、i<=M-1)//循環(huán)找到最佳的空閑分區(qū){if(free_table[i].flag==1&&need_length<=free_table[i].length){count++;if(count==1

5、

6、free_table[i].length

7、address;len=free_table[k].length;}else{//切割空閑區(qū)ads=free_table[k].address;len=need_length;free_table[k].address+=need_length;free_table[k].length-=need_length;}i=0;//循環(huán)尋找內(nèi)存分配表中標(biāo)志為空欄目的項(xiàng)while(used_table[i].flag!=0){i=i+1;}if(i<=N-1)//找到,在已分配區(qū)表中登記一個(gè)表項(xiàng){used_table[i]

8、.address=ads;used_table[i].length=len;used_table[i].flag=process_name;count1++;}else//已分配區(qū)表長(zhǎng)度不足{if(free_table[k].flag==0)//將已做的整個(gè)分配撤銷{free_table[k].flag=1;free_table[k].address=ads;free_table[k].length=len;}else//將已做的切割分配撤銷{free_table[k].address=ads;free_table

9、[k].length+=len;}cout<<"內(nèi)存分配區(qū)已滿,分配失??!";return0;}}else{cout<<"無(wú)法為該作業(yè)找到合適分區(qū)!";return0;}returnprocess_name;}intrecycle(intprocess_name){inty=0;floatrecycle_address,recycle_length;inti,j,k;//j欄是下鄰空閑區(qū),k欄是上欄空閑區(qū)intx;//在內(nèi)存分配表中找到要回收的作業(yè)while(y<=N-1&&used_table[y].fl

10、ag!=process_name){y=y+1;}if(y<=N-1)//找到作業(yè)后,將該欄的標(biāo)志置為'0'{recycle_address=used_table[y].address;recycle_length=used_table[y].length;used_table[y].flag=0;count2++;}else//未能找到作業(yè),回收失敗{co

當(dāng)前文檔最多預(yù)覽五頁(yè),下載文檔查看全文

此文檔下載收益歸作者所有

當(dāng)前文檔最多預(yù)覽五頁(yè),下載文檔查看全文
溫馨提示:
1. 部分包含數(shù)學(xué)公式或PPT動(dòng)畫的文件,查看預(yù)覽時(shí)可能會(huì)顯示錯(cuò)亂或異常,文件下載后無(wú)此問題,請(qǐng)放心下載。
2. 本文檔由用戶上傳,版權(quán)歸屬用戶,天天文庫(kù)負(fù)責(zé)整理代發(fā)布。如果您對(duì)本文檔版權(quán)有爭(zhēng)議請(qǐng)及時(shí)聯(lián)系客服。
3. 下載前請(qǐng)仔細(xì)閱讀文檔內(nèi)容,確認(rèn)文檔內(nèi)容符合您的需求后進(jìn)行下載,若出現(xiàn)內(nèi)容與標(biāo)題不符可向本站投訴處理。
4. 下載文檔時(shí)可能由于網(wǎng)絡(luò)波動(dòng)等原因無(wú)法下載或下載錯(cuò)誤,付費(fèi)完成后未能成功下載的用戶請(qǐng)聯(lián)系客服處理。