实验四 动态分区分配方式的模拟 答案

实验四 动态分区分配方式的模拟 答案

ID:6633388

大小:68.50 KB

页数:7页

时间:2018-01-20

实验四  动态分区分配方式的模拟 答案_第1页
实验四  动态分区分配方式的模拟 答案_第2页
实验四  动态分区分配方式的模拟 答案_第3页
实验四  动态分区分配方式的模拟 答案_第4页
实验四  动态分区分配方式的模拟 答案_第5页
资源描述:

《实验四 动态分区分配方式的模拟 答案》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、动态分区分配方式的模拟第一部分设计思想的说明1设计目标用C语言或C++语言分别实现采用首次适应算法和最佳适应算法的动态分区分配过程alloc()和回收过程free()。其中,空闲分区通过空闲分区链表来管理,在进行内存分配时,系统优先使用空闲区低端空间。预期结果:假设初始状态如下,可用的内存空间为640KB,并有下列请求序列:作业1申请130KB作业2申请60KB作业3申请100KB作业2释放60KB作业4申请200KB作业3释放100KB作业1释放130KB作业5申请140KB作业6申请60KB作业7申请50KB作业6释放60KB分别用首次适应算法和最佳适应算法进行内存块的

2、分配和回收,同时显示内存块分配和回收后空闲内存分区链的情况。2、设计理论首次适应算法(First-fit):当要分配内存空间时,就查表,在各空闲区中查找满足大小要求的可用块。只要找到第一个足以满足要球的空闲块就停止查找,并把它分配出去;如果该空闲空间与所需空间大小一样,则从空闲表中取消该项;如果还有剩余,则余下的部分仍留在空闲表中,但应修改分区大小和分区始址。 最佳适应算法(Best-fit):当要分配内存空间时,就查找空闲表中满足要求的空闲块,并使得剩余块是最小的。然后把它分配出去,若大小恰好合适,则直按分配;若有剩余块,则仍保留该余下的空闲分区,并修改分区大小的起始地址

3、。 内存回收:将释放作业所在内存块的状态改为空闲状态,删除其作业名,设置为空。并判断该空闲块是否与其他空闲块相连,若释放的内存空间与空闲块相连时,则合并为同一个空闲块,同时修改分区大小及起始地址。  第二部分程序清单 //***************************************************************//********动态分区分配方式的模拟*********//*************************************************************** #include

4、#include #defineFree0//空闲状态#defineBusy1//已用状态#defineOK1//完成#defineERROR0//出错#defineMAX_length640//最大内存空间为640KBtypedefintStatus; typedefstructfreearea//定义一个空闲区说明表结构{intID;//分区号longsize;//分区大小longaddress;//分区地址intstate;//状态}ElemType; //----------线性表的双向链表存储结构------------typedefstruc

5、tDuLNode//doublelinkedlist{ElemTypedata;structDuLNode*prior;//前趋指针structDuLNode*next;//后继指针}DuLNode,*DuLinkList; DuLinkListblock_first;//头结点DuLinkListblock_last;//尾结点 Statusalloc(int);//内存分配Statusfree(int);//内存回收StatusFirst_fit(int,int);//首次适应算法StatusBest_fit(int,int);//最佳适应算法voidshow();//

6、查看分配StatusInitblock();//开创空间表 StatusInitblock()//开创带头结点的内存空间链表{block_first=(DuLinkList)malloc(sizeof(DuLNode));block_last=(DuLinkList)malloc(sizeof(DuLNode));block_first->prior=NULL;block_first->next=block_last;block_last->prior=block_first;block_last->next=NULL;block_last->data.address=0;

7、block_last->data.size=MAX_length;block_last->data.ID=0;block_last->data.state=Free;returnOK;} //-----------------------分配主存-------------------------Statusalloc(intch){intID,request;cout<<"请输入作业(分区号):";cin>>ID;cout<<"请输入需要分配的主存大小(单位:KB):";cin>>request;if(reques

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。