




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、實(shí)驗(yàn)三動(dòng)態(tài)分區(qū)存儲(chǔ)管理一:實(shí)驗(yàn)?zāi)康牧私鈩?dòng)態(tài)分區(qū)存儲(chǔ)管理方式中的數(shù)據(jù)結(jié)構(gòu)和分配算法,加深對(duì)動(dòng)態(tài)分區(qū)存儲(chǔ)管理方式及其實(shí)現(xiàn)技術(shù)的理解。二:實(shí)驗(yàn)內(nèi)容用C語言或Pascal語言分別實(shí)現(xiàn)采用首次適應(yīng)算法和最佳適應(yīng)算法的動(dòng)態(tài)分區(qū)分配過程Allocate()和回收過程Free()。其中,空閑分區(qū)采用空閑分區(qū)鏈來組織,內(nèi)存分配時(shí),優(yōu)先使用空閑區(qū)低地址部分的空間。三:實(shí)驗(yàn)類別動(dòng)態(tài)分區(qū)存儲(chǔ)管理四:實(shí)驗(yàn)類型模擬實(shí)驗(yàn)五:主要儀器計(jì)算機(jī)六:結(jié)果和小結(jié)七:程序#include<stdio.h>#include<time.h>#include<stdlib.h>#define SIZE 6
2、40 / 內(nèi)存初始大小#define MINSIZE 5 / 碎片最小值struct memorystruct memory *former;/前向指針int address;/地址int num;/作業(yè)號(hào)int size;/分配內(nèi)存大小int state;/狀態(tài)0表示空閑,1表示已分配struct memory *next;/后向指針linklist;void intmemory()/ 初始化空閑分區(qū)鏈memory *p=(memory *)malloc(sizeof(memory);/ 分配初始分區(qū)內(nèi)存 p->address=0;/ 給首個(gè)分區(qū)賦值 p->size=SIZE;
3、p->state=0; p->num=-1; p->former=&linklist; p->next=NULL; linklist.former=NULL;/ 初始化分區(qū)頭部信息 linklist.next=p;int firstFit(int num, int size)/ 首次適應(yīng)算法memory *p = linklist.next;while(p != NULL)if(p->state = 0 && p->size >= size) / 找到要分配的空閑分區(qū)if(p->size - size <= MINS
4、IZE)/ 整塊分配p->state = 1; p->num = num; else / 分配大小為size的區(qū)間 memory *node=(memory *)malloc(sizeof(memory); node->address=p->address + size; node->size=p->size-size; node->state=0; node->num=-1; / 修改分區(qū)鏈節(jié)點(diǎn)指針 node->former=p; node->next=p->next; if(p->next !=NULL) p->
5、next->former=node; p->next = node; / 分配空閑區(qū)間 p->size = size; p->state = 1; p->num = num; printf("內(nèi)存分配成功!n"); return 1; p = p->next; printf("找不到合適的內(nèi)存分區(qū),分配失敗.n"); return 0;int bestFit(int num, int size)/ 最佳適應(yīng)算法 memory *tar=NULL; int tarSize=SIZE + 1; memory *p=link
6、list.next; while(p!=NULL) if(p->state=0 && p->size >= size && p->size < tarSize) /尋找最佳空閑區(qū)間 tar=p; tarSize=p->size; p=p->next; if(tar!=NULL) if(tar->size - size <= MINSIZE) /找到要分配的空閑分區(qū)tar->state = 1;/ 整塊分配 tar->num=num; else / 分配大小為size的區(qū)間 memory *node
7、 = (memory *)malloc(sizeof(memory); node->address = tar->address + size; node->size = tar->size - size; node->state = 0; node->num = -1; / 修改分區(qū)鏈節(jié)點(diǎn)指針 node->former = tar; node->next = tar->next; if(tar->next != NULL) tar->next->former = node; tar->next = node; /
8、分配空閑區(qū)間 tar->size = size; tar->state = 1; tar->num = num; printf("內(nèi)存分配成功!n"); return 1; else / 找不到合適的空閑分區(qū) printf("找不到合適的內(nèi)存分區(qū),分配失敗!n"); return 0; int freememory(int num)/ 回收內(nèi)存 int flag=0; memory *p=linklist.next, *pp; while(p!=NULL) if(p->state=1 && p->num=nu
9、m) flag = 1; if(p->former!= &linklist && p->former->state = 0) && (p->next != NULL && p->next->state = 0) / 情況1:合并上下兩個(gè)分區(qū) / 先合并上區(qū)間 pp=p; p=p->former; p->size+=pp->size; p->next=pp->next; pp->next->former=p; free(pp); / 后合并下區(qū)間 pp=p->
10、;next; p->size+=pp->size; p->next=pp->next; if(pp->next!=NULL) pp->next->former=p; free(pp); else if(p->former=&linklist | p->former->state=1)&& (p->next!=NULL&&p->next->state =0) / 情況2:只合并下面的分區(qū) pp=p->next; p->size+=pp->size; p->
11、state=0; p->num=-1; p->next=pp->next; if(pp->next!= NULL) pp->next->former=p; free(pp); else if(p->former!=&linklist&&p->former->state=0)&& (p->next=NULL | p->next->state=1) / 情況3:只合并上面的分區(qū) pp=p; p=p->former; p->size+=pp->size; p->ne
12、xt=pp->next; if(pp->next != NULL) pp->next->former = p; free(pp); else / 情況4:上下分區(qū)均不用合并 p->state=0; p->num=-1; p=p->next; if(flag=1) / 回收成功 printf("內(nèi)存分區(qū)回收成功.n"); return 1; else / 找不到目標(biāo)作業(yè),回收失敗 printf("找不到目標(biāo)作業(yè),內(nèi)存分區(qū)回收失敗.n"); return 0; / 顯示空閑分區(qū)鏈情況void showmemory()
13、 printf(" 當(dāng)前的內(nèi)存分配情況如下: n"); printf("*n"); printf(" 起始地址 | 空間大小 | 工作狀態(tài) | 作業(yè)號(hào) n"); memory *p=linklist.next; while(p!=NULL) printf("*n"); printf("*"); printf("%5d k |", p->address); printf("%5d k |", p->size); printf(" %5s
14、 |", p->state = 0 ? "0" : "1"); if(p->num > 0) printf("%5d ", p->num); else printf(" "); p = p->next; int main() int option, ope, num, size; / 初始化空閑分區(qū)鏈 intmemory(); / 選擇分配算法l1: while(1) printf("*n"); printf("請(qǐng)選擇要模擬的分配算法:n1表示首
15、次適應(yīng)算法n2表示最佳適應(yīng)算法n"); printf("*n"); scanf("%d", &option);system("cls"); if(option=1) printf("你選擇了首次適應(yīng)算法,下面進(jìn)行算法的模擬n"); break; else if(option=2) printf("你選擇了最佳適應(yīng)算法,下面進(jìn)行算法的模擬n"); break; else printf("錯(cuò)誤:請(qǐng)輸入 0/1nn"); / 模擬動(dòng)態(tài)分區(qū)分配算法 while(1)
16、 printf("n"); printf("*n"); printf("1:分配內(nèi)存n 2:回收內(nèi)存n 3:返回上一級(jí)菜單nn"); printf("*n"); scanf("%d", &ope);system("cls"); if(ope=0) break; if(ope=1) / 模擬分配內(nèi)存 printf("請(qǐng)輸入作業(yè)號(hào): "); scanf("%d", &num); printf("請(qǐng)輸入需要分配的內(nèi)存大小(KB): "); scanf("%d", &size); if(size<=0) printf("錯(cuò)誤:分配內(nèi)存大小必須為正值n"); continue; / 調(diào)用分配算法 if(option=0) firstFit(num, size); else bestFit(num, size);
溫馨提示
- 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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 三農(nóng)村信息化建設(shè)與信息資源共享方案
- 停車場(chǎng)經(jīng)營(yíng)承包合同協(xié)議書
- 建筑工程合伙承包協(xié)議書
- 工作效率提升方案說明書
- 化工原理及化學(xué)反應(yīng)工程試題集
- 土方開挖及基坑支護(hù)施工方案
- 道具露天隧道施工方案
- 鋼管卸料平臺(tái)施工方案
- 凍庫施工方案
- 拆除內(nèi)隔墻及地面施工方案
- 2025年常州工業(yè)職業(yè)技術(shù)學(xué)院?jiǎn)握新殬I(yè)技能測(cè)試題庫及答案1套
- 2025年湖南理工職業(yè)技術(shù)學(xué)院?jiǎn)握新殬I(yè)適應(yīng)性測(cè)試題庫必考題
- 2025年湖南城建職業(yè)技術(shù)學(xué)院?jiǎn)握新殬I(yè)技能測(cè)試題庫完美版
- 會(huì)計(jì)信息化練習(xí)題庫+參考答案
- 2024《整治形式主義為基層減負(fù)若干規(guī)定》全文課件
- 網(wǎng)課智慧樹知道《老年醫(yī)學(xué)概論(浙江大學(xué))》章節(jié)測(cè)試答案
- MOOC 數(shù)據(jù)庫系統(tǒng)(中):建模與設(shè)計(jì)-哈爾濱工業(yè)大學(xué) 中國(guó)大學(xué)慕課答案
- 日語綜合教程第五冊(cè)的PPT5-1
- 外購件采購清單模版(含標(biāo)準(zhǔn)件、外購件、自制件)
- 事業(yè)單位工作員年度考核方案3篇
- 富順縣柑橘產(chǎn)業(yè)發(fā)展規(guī)劃
評(píng)論
0/150
提交評(píng)論