




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
1、/該文件所含代碼是課設(shè)需要學(xué)生自己寫的代碼和補(bǔ)充的代碼,包含部分需要修改的課程設(shè)計(jì)指導(dǎo)書中的代碼,不包含不需修改的代碼/1.顯示空閑區(qū)表void display_freearea_list() FREEAREA *p;char buffer20; p=p_free_area_list;printf("|-|-|n");printf("| start_address(kB) | size(KB) |n");printf("|-|-|n");while(p!=NULL)printf("| %d",p->start
2、_address);itoa( p->start_address, buffer, 10 );print_space(19-strlen(buffer);printf("| %d",p->size);itoa(p->size, buffer, 10 );print_space(17-strlen(buffer);printf("|n");p=p->next; printf("|-|-|nn");/2.最先適應(yīng)分配法:內(nèi)存釋放函數(shù)void FF_release_memory(int start_address,i
3、nt size)EnterCriticalSection(&CS_FREEAREA_LIST);_int64 t1, t2;/記錄該算法起止時(shí)間t1 = GetCycleCount();/記錄起始時(shí)間FREEAREA *temp,*p,*pp;/將空閑區(qū)按start_address由小到大排序,以便整合相鄰空閑區(qū)while(1)int change = 0;p = p_free_area_list;if(p->next != NULL)if(p->start_address > p->next->start_address)pp = p->next;
4、p->next = pp->next;pp->next = p;p_free_area_list = pp;change = 1;if(p->next != NULL)while(p->next->next != NULL)if(p->next->start_address > p->next->next->start_address )pp = p->next->next;p->next->next = pp->next;pp->next = p->next;p->next
5、 = pp;change = 1;p = p->next ;if(change = 0)break;/插入空閑區(qū)temp = new FREEAREA;p = new FREEAREA;temp->start_address = start_address;temp->size = size;temp->next = NULL;p->next = p_free_area_list;while(p->next != NULL)if(p->next->start_address > temp->start_address)temp->
6、;next = p->next ;p->next = temp;break;elsep = p->next ;if(p->next = NULL)p->next = temp;else if(temp->next = p_free_area_list)p_free_area_list = temp;/整合碎片while(1)int change = 0;p = p_free_area_list;if(p = NULL)break;while(p->next != NULL)if(p->start_address + p->size) = (
7、p->next->start_address)p->size = p->next->size + p->size;change = 1; if(p->next->next = NULL)free(p->next);p->next = NULL;elsep->next = p->next->next;if(p->next = NULL)break;elsep = p->next ;if(change = 0)break;/整理線程結(jié)束后的駐留鏈表THREAD_RESIDENCE_MEMORY *q;q =
8、p_thread_residence_memory_list;if(q->start_address = start_address)p_thread_residence_memory_list = p_thread_residence_memory_list->next ;elsewhile(q->next != NULL)if(q->next->start_address = start_address)if(q->next = tail_thread_residence_memory_list)tail_thread_residence_memory_
9、list = q;q->next = q->next->next ;break;q = q->next;/記錄結(jié)束時(shí)間,并將運(yùn)行時(shí)間存入對應(yīng)數(shù)組t2 = GetCycleCount();if(time00 > t2 - t1)time00 = t2 - t1;if(time01 < t2 - t1)time01 = t2 - t1; LeaveCriticalSection(&CS_FREEAREA_LIST);/3.最佳適應(yīng)分配算法的內(nèi)存釋放函數(shù)void BF_release_memory(int start_address,int size)En
10、terCriticalSection(&CS_FREEAREA_LIST);_int64 t1, t2;/記錄該算法起止時(shí)間t1 = GetCycleCount();/記錄起始時(shí)間FREEAREA *temp,*p,*pp;/將空閑區(qū)按start_address由小到大排序,以便整合相鄰空閑區(qū)while(1)int change = 0;p = p_free_area_list;if(p->next != NULL)if(p->start_address > p->next->start_address)pp = p->next;p->next
11、 = pp->next;pp->next = p;p_free_area_list = pp;change = 1;if(p->next != NULL)while(p->next->next != NULL)if(p->next->start_address > p->next->next->start_address )pp = p->next->next;p->next->next = pp->next;pp->next = p->next;p->next = pp;chan
12、ge = 1;p = p->next ;if(change = 0)break;/插入空閑區(qū)temp = new FREEAREA;p = new FREEAREA;temp->start_address = start_address;temp->size = size;temp->next = NULL;p->next = p_free_area_list;while(p->next != NULL)if(p->next->start_address > temp->start_address)temp->next = p-
13、>next ;p->next = temp;break;elsep = p->next ;if(p->next = NULL)p->next = temp;else if(temp->next = p_free_area_list)p_free_area_list = temp;/整合碎片while(1)int change = 0;p = p_free_area_list;if(p = NULL)break;while(p->next != NULL)if(p->start_address + p->size) = (p->next
14、->start_address)p->size = p->next->size + p->size;change = 1; if(p->next->next = NULL)free(p->next);p->next = NULL;elsep->next = p->next->next;if(p->next = NULL)break;elsep = p->next ;if(change = 0)break;/將空閑區(qū)按SIZE由小到大排序,以便符合BF算法while(1)int change = 0;p = p_
15、free_area_list;if(p->size > p->next->size)pp = p->next;p->next = pp->next;pp->next = p;p_free_area_list = pp;change = 1;while(p->next->next != NULL)if(p->next->size > p->next->next->size )pp = p->next->next;p->next->next = pp->next;pp-&g
16、t;next = p->next;p->next = pp;change = 1;p = p->next ;if(change = 0)break;/整理線程結(jié)束后的駐留鏈表THREAD_RESIDENCE_MEMORY *q;q = p_thread_residence_memory_list;if(q->start_address = start_address)p_thread_residence_memory_list = p_thread_residence_memory_list->next ;elsewhile(q->next != NULL)
17、if(q->next->start_address = start_address)if(q->next = tail_thread_residence_memory_list)tail_thread_residence_memory_list = q;q->next = q->next->next ;break;q = q->next;/記錄結(jié)束時(shí)間,并將運(yùn)行時(shí)間存入對應(yīng)數(shù)組t2 = GetCycleCount();if(time10 > t2 - t1)time10 = t2 - t1;if(time11 < t2 - t1)time1
18、1 = t2 - t1; LeaveCriticalSection(&CS_FREEAREA_LIST);/4.最壞適應(yīng)分配算法:內(nèi)存釋放函數(shù)void WF_release_memory(int start_address,int size)EnterCriticalSection(&CS_FREEAREA_LIST);_int64 t1, t2;/記錄該算法起止時(shí)間t1 = GetCycleCount();/記錄起始時(shí)間FREEAREA *temp,*p,*pp;/將空閑區(qū)按start_address由小到大排序,以便整合相鄰空閑區(qū)while(1)int change = 0
19、;p = p_free_area_list;if(p->next != NULL)if(p->start_address > p->next->start_address)pp = p->next;p->next = pp->next;pp->next = p;p_free_area_list = pp;change = 1;if(p->next != NULL)while(p->next->next != NULL)if(p->next->start_address > p->next->n
20、ext->start_address )pp = p->next->next;p->next->next = pp->next;pp->next = p->next;p->next = pp;change = 1;p = p->next ;if(change = 0)break;/插入空閑區(qū)temp = new FREEAREA;temp->start_address = start_address;temp->size = size;temp->next = NULL;p = new FREEAREA;p->
21、next = p_free_area_list;while(p->next != NULL)if(p->next->start_address > temp->start_address)temp->next = p->next ;p->next = temp;break;elsep = p->next ;if(p->next = NULL)p->next = temp;else if(temp->next = p_free_area_list)p_free_area_list = temp;/整合碎片while(1)in
22、t change = 0;p = p_free_area_list;if(p = NULL)break;while(p->next != NULL)if(p->start_address + p->size) = (p->next->start_address)p->size = p->next->size + p->size;change = 1; if(p->next->next = NULL)free(p->next);p->next = NULL;elsep->next = p->next->
23、;next;if(p->next = NULL)break;elsep = p->next ;if(change = 0)break;/將空閑區(qū)按SIZE由大到小排序,以便符合WF算法while(1)int change = 0;p = p_free_area_list;if(p->size < p->next->size)pp = p->next;p->next = pp->next;pp->next = p;p_free_area_list = pp;change = 1;while(p->next->next !=
24、NULL)if(p->next->size < p->next->next->size )pp = p->next->next;p->next->next = pp->next;pp->next = p->next;p->next = pp;change = 1;p = p->next ;if(change = 0)break;/整理線程結(jié)束后的駐留鏈表THREAD_RESIDENCE_MEMORY *q;q = p_thread_residence_memory_list;if(q->start_
25、address = start_address)p_thread_residence_memory_list = p_thread_residence_memory_list->next ;elsewhile(q->next != NULL)if(q->next->start_address = start_address)if(q->next = tail_thread_residence_memory_list)tail_thread_residence_memory_list = q;q->next = q->next->next ;break;q = q->next;/記錄結(jié)束時(shí)間,并將運(yùn)行時(shí)間存入對應(yīng)數(shù)組t2 = GetCycleCount();if(time20 > t2 - t1)time20 = t2 - t1;if(time21 < t2 - t1)time21 = t2 - t1; LeaveCriticalSection(&CS_FREEAREA_LIST);/5.二維數(shù)組,用于存放各種算法所需的最長時(shí)間和最短時(shí)間_int64 time32 = 99999999,0,99999999,0,99999999,0;/6.顯示程序運(yùn)行時(shí)間void display_time(int
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(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ǔ)空間,僅對用戶上傳內(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)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 在實(shí)際中 翻譯
- 生物工程 畢業(yè)論文
- 初中地理新課標(biāo)培訓(xùn)課件
- 椎間孔鏡髓核摘除術(shù)
- excel辦公軟件培訓(xùn)課件
- 發(fā)票新規(guī)培訓(xùn)
- 古箏銷售技巧培訓(xùn)
- 豬場防疫知識(shí)培訓(xùn)
- 腫瘤專科護(hù)士工作心得
- 天津兒童繪畫培訓(xùn)課件
- T/ISEAA 006-2024大模型系統(tǒng)安全測評要求
- 2025龍巖市上杭縣藍(lán)溪鎮(zhèn)社區(qū)工作者考試真題
- 礦山股東協(xié)議書
- 2025年教育管理與政策研究考試試題及答案
- 少隊(duì)工作計(jì)劃的風(fēng)險(xiǎn)控制措施
- 2025-2031年中國天然氣勘探行業(yè)市場運(yùn)行態(tài)勢及投資潛力研判報(bào)告
- 2025年新媒體運(yùn)營專員面試題及答案
- 四川綿陽公開招聘社區(qū)工作者考試高頻題庫帶答案2025年
- 《水利工程造價(jià)與招投標(biāo)》課件-模塊六 招投標(biāo)程序
- 關(guān)于水表考試題及答案
- 落實(shí)責(zé)任制整體護(hù)理總結(jié)
評論
0/150
提交評論