亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

模擬可變分區存儲管理的內存分配(C)

2019-11-06 08:16:24
字體:
來源:轉載
供稿:網友

要求:

系統根據申請者的要求,按照一定的分配策略分析內存空間的使用情況,找出能滿足請求的空閑區,分給申請者;當程序執行完畢或主動歸還內存資源時,系統要收回它所占用的內存空間或它歸還的部分內存空間,主存分配算法使用最壞適應分配算法。

程序運行時根據文件內容初始化空閑區表,文件內容為每行兩項:起始地址 長度 中間以逗號隔開,文件內容如下:

10,313,417,230,838,7

可變分區存儲管理的內存分配方案一般采用"已分配區表"和"空閑區表"來記錄主存已分配和未分配的情況,本例中采用單向鏈表方式來表示兩種結構。

分配內存時:從"空閑區表"中找出一項能滿足申請空間的記錄,然后分割該項,如果分割出剩余空間,則將剩余空間重新放入"空閑區表"中,同時產生一個"已分配區記錄項",該記錄的長度為申請的空間大小,起始地址為分割的"空閑區"項的起始地址。并將該記錄插入到"已分配區表"中。

回收作業內存時:刪除該作業在"已分配區表"中的記錄項,并按該項的地址和長度創建一個"空閑區"記錄,遍歷"空閑區表",如果存在上邊界相鄰或者下邊界相鄰的記錄項,則合并兩者(無相鄰區塊,不需要做任何操作),最后將該記錄插入到"空閑區表"中,并使之滿足降序條件。

空閑區表數據結構:

//空閑區表struct free_link{	int saddr;//起始地址	int len;//長度	int flag;//標志	struct free_link *next;};已分配區表數據結構:

//已分配區表struct alloc_link{	int saddr;//起始地址	int len;//長度	int work;//作業名	struct alloc_link *next;};

最壞適應分配算法:

空閑區表中每個記錄項按照長度遞減的順序排列,當需要分配空間時,只需要從表中取出第一項,然后為任務分割空間即可,如果分割后有剩余空間則將剩余部分再次插入空閑區表中,并重新調整表中記錄項,使得滿足按照長度遞減順序。

分配內存流程圖:

內存回收流程圖:

在回收內存時,會涉及到回收的空閑塊可能會與"空閑區表"中的某個記錄項上邊界相鄰或者下邊界相鄰或者上下邊界都有相鄰的空閑塊,這時候就需要合并要回收的記錄塊和已有的空閑塊,本例中采用的方式是:先根據要回收的"已分配區表"中的記錄項A,生成一個地址和長度相同的空閑塊記錄B,然后遍歷"空閑區塊表",發現有上邊界相鄰的記錄項C,則修改B的起始地址為C記錄中的起始地址,長度為B塊的長度+C塊的長度,然后從鏈表中刪除記錄C,繼續遍歷,如果發現有下邊界相鄰的記錄D,則再修改C的長度為原有長度+D的記錄長度,從鏈表中再把記錄D刪除,這樣直到遍歷到鏈表尾部。此時4中不同情況都已經包含(上邊界相鄰、下邊界相鄰,上下邊界同時相鄰、無相鄰),只需要將記錄B插入到"空閑區表"中即可。

空閑塊合并核心代碼:

        //空閑塊頭指針 	fp = free_head;	while(fp->next != NULL)	{		//上邊界相同 		if((fp->next->saddr + fp->next->len) == fitem->saddr)		{			//上邊界與待回收的空間邊界進行合并 			fitem->saddr = fp->next->saddr;			fitem->len = fp->next->len + fitem->len;			//釋放原有空閑塊的內存 			tmp_item = fp->next;			fp->next = tmp_item->next;			tmp_item->next = NULL;			free(tmp_item);			tmp_item = NULL;		}				if((fitem->saddr + fitem->len) == fp->next->saddr)		{			//下邊界與待回收的空間邊界合并 			fitem->len = fitem->len + fp->next->len;			//釋放原有空閑塊內存			tmp_item = fp->next;			fp->next = tmp_item->next;			tmp_item->next = NULL;			free(tmp_item);			tmp_item = NULL;		}				//如果已經遍歷到鏈尾則跳出 		if(fp->next == NULL)		{			break;		}				fp = fp->next; 	}		//重新調整空閑區表,按空間遞減順序排列	fp = free_head;	while(fp->next != NULL)	{		if(fp->next->len <= fitem->len)		{			break;		}		fp = fp->next;	}		fitem->next = fp->next;	fp->next = fitem;

空閑塊合并示意圖如下:

空閑區表和已分配區表在分配和回收過程中變化效果圖:

代碼示例


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产69久久精品成人看| 狠狠躁夜夜躁人人躁婷婷91| 欧美日韩午夜视频在线观看| 亚洲欧美福利视频| 欧美三级免费观看| 欧美重口另类videos人妖| 色天天综合狠狠色| 国产精品久久久久久久久久久久| 欧美中文在线视频| 91九色单男在线观看| 国产精品福利在线| 国产在线视频不卡| 日韩在线观看精品| 免费av在线一区| 亚洲人成在线电影| 成人久久18免费网站图片| 在线观看中文字幕亚洲| 亚洲黄色av女优在线观看| 国产精品一区二区三区免费视频| 国产91色在线播放| 中文字幕一精品亚洲无线一区| 欧美激情国产高清| 欧美激情视频三区| 日韩av在线免费观看一区| 992tv在线成人免费观看| 九九热99久久久国产盗摄| 亚洲精品久久久久久久久| 久久精品视频亚洲| 亚洲国产精品成人一区二区| 黄色精品在线看| 久久躁日日躁aaaaxxxx| 91久久精品久久国产性色也91| 国产999精品久久久影片官网| 午夜免费在线观看精品视频| 日韩女优人人人人射在线视频| 日韩hd视频在线观看| 国外日韩电影在线观看| 亚洲国产小视频在线观看| 91精品免费视频| 成人福利在线观看| 国产乱人伦真实精品视频| 国产97在线播放| 欧美成人免费网| 国产一区av在线| 精品少妇一区二区30p| 欧美精品一区三区| 欧美性20hd另类| 91网站免费观看| 日韩欧美国产黄色| 国产一区视频在线播放| 热久久美女精品天天吊色| 91地址最新发布| 亚洲国产精品久久久久秋霞不卡| 亚洲第一福利网| 亚洲成av人片在线观看香蕉| 91欧美日韩一区| 色综合91久久精品中文字幕| 久久综合久久美利坚合众国| 久久久精品久久| 97在线精品国自产拍中文| 欧美日韩免费看| 2019精品视频| 97国产精品免费视频| 久久影视电视剧凤归四时歌| 国产日韩换脸av一区在线观看| 456亚洲影院| 久久久久久久久久国产| 8050国产精品久久久久久| 国产精品av在线播放| 精品毛片三在线观看| 国产精品海角社区在线观看| 欧美超级乱淫片喷水| 日韩av在线免费看| 国产亚洲视频中文字幕视频| 亚洲精品久久7777777| 亚洲石原莉奈一区二区在线观看| 亚洲精品国产免费| 国产精品精品久久久| 国产xxx69麻豆国语对白| 91久久国产精品| 日韩电影大全免费观看2023年上| 在线视频精品一| 欧美与黑人午夜性猛交久久久| 国产精品美乳一区二区免费| 欧美日韩美女在线| 欧美日韩在线免费| 最近的2019中文字幕免费一页| 欧美高清自拍一区| 亚洲国产精品va在看黑人| 亚洲综合中文字幕68页| 亚洲精品色婷婷福利天堂| 亚洲欧美日韩久久久久久| 日韩精品福利在线| 亚洲国产精品成人av| 亚洲欧美自拍一区| 欧美最近摘花xxxx摘花| 欧美精品videos另类日本| 国产成人精品免费视频| 日本国产精品视频| 欧美尺度大的性做爰视频| 久久成人人人人精品欧| 日韩激情av在线播放| 国产日韩欧美在线看| 在线视频欧美性高潮| 精品久久久久久久久久久| 日韩成人在线视频观看| 亚洲国产精久久久久久| 日韩欧美在线视频观看| 热久久99这里有精品| 成人免费视频a| 日韩精品极品视频免费观看| 国产免费一区二区三区香蕉精| 日韩精品免费看| 国产精品一区二区久久久| 亚洲欧美三级伦理| 免费不卡欧美自拍视频| 日韩成人性视频| 在线电影欧美日韩一区二区私密| 欧美在线影院在线视频| 日本在线观看天堂男亚洲| 欧美成人午夜免费视在线看片| 日韩a**站在线观看| 国产精品丝袜久久久久久高清| 国产成人精品视频在线| 日韩一区二区av| 欧美国产一区二区三区| 亚洲男人av电影| 最新亚洲国产精品| 最近2019中文免费高清视频观看www99| 日韩精品免费电影| 欧美一级免费视频| 久久人人爽亚洲精品天堂| 九九九热精品免费视频观看网站| 精品国偷自产在线| 欧美中文字幕在线观看| 亚洲福利影片在线| 欧美极度另类性三渗透| 成人精品aaaa网站| 1769国产精品| 色播久久人人爽人人爽人人片视av| 欧美一区二区三区艳史| 在线电影av不卡网址| 亚洲最新av在线| 欧美xxxx综合视频| 亚洲经典中文字幕| 欧美一级bbbbb性bbbb喷潮片| 国产日韩精品一区二区| 97人洗澡人人免费公开视频碰碰碰| 富二代精品短视频| 91精品国产综合久久香蕉的用户体验| 91国产在线精品| 26uuu久久噜噜噜噜| 91在线观看免费网站| 中文字幕一区二区三区电影| 黑人巨大精品欧美一区二区一视频| 国产ts一区二区| 亚洲男人的天堂在线播放| 久久国产精品电影| 国产999精品久久久影片官网| 美女撒尿一区二区三区| 久久久久久97| 国产日韩综合一区二区性色av| 91精品国产高清自在线看超| 国产精品美女主播在线观看纯欲|