欢迎来到天天文库
浏览记录
ID:59536850
大小:154.50 KB
页数:11页
时间:2020-11-09
《分区存储管理模拟实验报告.doc》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、分区存储管理模拟实验报告1.实验目的了解动态分区存储管理方式中的数据结构和分配算法,加深对动态分区存储管理方式及其实现技术的理解。2.实验内容§用C语言或Pascal语言分别实现采用首次适应算法和最佳适应算法的动态分区分配过程Allocate()和回收过程Free()。其中,空闲分区采用空闲分区链来组织,内存分配时,优先使用空闲区低地址部分的空间。§假设初始状态,可用内存空间为640KB,作业请求序列如下(也可以编程从键盘输入,R表示请求,F表示释放):²作业1请求130KB。²作业2请求60KB。²作业3请求100KB。²作业2释放60KB。²作业
2、4请求200KB。²作业3释放100KB。²作业1释放130KB。²作业5请求140KB。²作业6请求60KB。²作业7请求50KB。²作业6释放60KB。§要求每次分配和回收后显示出空闲区链的情况。§如果不能为作业的请求进行内存分配,给出相应的提示信息。3.实验分析和思考§采用首次适应算法和最佳适应算法,对内存的分配和回收速度有什么影响?§如何解决碎片片问题?详细设计首次适应算法:当要分配内存空间时,就查表,在各空闲区中查找满足大小要求的可用块。只要找到第一个足以满足要球的空闲块就停止查找,并把它分配出去;如果该空闲空间与所需空间大小一样,则从空闲
3、表中取消该项;如果还有剩余,则余下的部分仍留在空闲表中,但应修改分区大小和分区始址。最佳适应算法:当要分配内存空间时,就查找空闲表中满足要求的空闲块,并使得剩余块是最小的。然后把它分配出去,若大小恰好合适,则直按分配;若有剩余块,则仍保留该余下的空闲分区,并修改分区大小的起始地址。内存回收:将释放作业所在内存块的状态改为空闲状态,删除其作业名,设置为空。并判断该空闲块是否与其他空闲块相连,若释放的内存空间与空闲块相连时,则合并为同一个空闲块,同时修改分区大小及起始地址。typedefstructfreearea{}ElemType;定义一个空闲区说明
4、表结构,每申请一个作业,改作业便具有此结构体typedefstructDuLNode{}DuLNode,*DuLinkList;定义一个双向链表StatusInitblock(){}开创带头结点的内存空间链表,通过双向链表把申请的作业链接起来,作业的插入和删除,和链表中节点的插入和删除类似。双向链表如图1所示StatusFirst_fit(intID,intrequest){}传入作业名及申请量采用首次适应算法实现动态内存分区分配的模拟,初始态640KB,只是一个虚态,每申请成功一个作业,便相应的640KB做相应的减少,同过双向链表模拟主存的分配情况
5、。内存分配流程如图2所示Statusfree(intID)传过来需要回收的分区号实现分区的回收,对不同情况采取不同的处理voidshow()显示当前主存的分配情况源程序//----------------------------------------------------------------//---------动态分区分配方式的模拟---------//----------------------------------------------------------------#include#include6、dlib.h>#defineFree0//空闲状态#defineBusy1//已用状态#defineOK1//完成#defineERROR0//出错#defineMAX_length640//最大内存空间为640KBtypedefintStatus;typedefstructfreearea//定义一个空闲区说明表结构{intID;//分区号longsize;//分区大小longaddress;//分区地址intstate;//状态}ElemType;//----------线性表的双向链表存储结构------------typedefstructD7、uLNode//doublelinkedlist{ElemTypedata;structDuLNode*prior;//前趋指针structDuLNode*next;//后继指针}DuLNode,*DuLinkList;DuLinkListblock_first;//头结点DuLinkListblock_last;//尾结点Statusalloc(int);//内存分配Statusfree(int);//内存回收StatusFirst_fit(int,int);//首次适应算法StatusBest_fit(int,int);//最佳适应算法voids8、how();//查看分配StatusInitblock();//开创空间表StatusInitblock()
6、dlib.h>#defineFree0//空闲状态#defineBusy1//已用状态#defineOK1//完成#defineERROR0//出错#defineMAX_length640//最大内存空间为640KBtypedefintStatus;typedefstructfreearea//定义一个空闲区说明表结构{intID;//分区号longsize;//分区大小longaddress;//分区地址intstate;//状态}ElemType;//----------线性表的双向链表存储结构------------typedefstructD
7、uLNode//doublelinkedlist{ElemTypedata;structDuLNode*prior;//前趋指针structDuLNode*next;//后继指针}DuLNode,*DuLinkList;DuLinkListblock_first;//头结点DuLinkListblock_last;//尾结点Statusalloc(int);//内存分配Statusfree(int);//内存回收StatusFirst_fit(int,int);//首次适应算法StatusBest_fit(int,int);//最佳适应算法voids
8、how();//查看分配StatusInitblock();//开创空间表StatusInitblock()
此文档下载收益归作者所有