计算机操作系统动态分区存储管理方式下的内存空间的分配与回收实验报告(共9页).doc
《计算机操作系统动态分区存储管理方式下的内存空间的分配与回收实验报告(共9页).doc》由会员分享,可在线阅读,更多相关《计算机操作系统动态分区存储管理方式下的内存空间的分配与回收实验报告(共9页).doc(9页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、精选优质文档-倾情为你奉上计算机操作系统实验报告实验二实验题目:存储器管理 系别:计算机科学与技术系 班级: 姓名: 学号:2一、实验目的深入理解动态分区存储管理方式下的内存空间的分配与回收。二、实验内容编写程序完成动态分区存储管理方式下的内存分配和回收的实现。具体内容包括:确定用来管理内存当前使用情况的数据结构;采用首次适应算法完成内存空间的分配;分情况对作业进行回收;编写主函数对所做工作进行测试。三、实验原理分配:动态分区存储管理方式把内存除OS占用区域外的空间看作一个大的空闲区。当作业要求装入内存时,根据作业需要内存空间的大小查询内存中各个空闲区,当从内存中找到一个大于或等于该作业大小的
2、内存空闲区时,选择其中一个空闲区,按作业要求划出一个分区装入该作业。回收:作业执行完后,它所占用的内存空间被收回,成为一个空闲区。如果该空闲区的相邻分区也是空闲区,则需要将相邻空闲区合并成一个空闲区。四、实验方法实现动态分区的分配与回收,主要考虑三个问题:第一、设计记录内存使用情况的数据表格,用来记录空闲区和作业占用的区域(利用结构体类型数组来保存数据);第二、在设计的数据表格基础上设计内存分配算法(采用首次适应算法找合适的分区(对空闲分区表进行排序),分配时要考虑碎片问题);第三、在设计的数据表格基础上设计内存回收算法(分四种情况进行回收(上邻、下邻、上下邻和无相邻分区)。五、实验步骤第一,
3、设计记录内存使用情况的数据表格l 已分配分区表:起始地址、长度、标志(0表示“空表项”,1表示“已分配”)l 空闲分区表: 起始地址、长度、标志(0表示“空表项”,1表示“未分配”)struct used_table float address; /已分分区起始地址float length; /已分分区长度,单位为字节int flag; /已分配表区登记栏标志,用0表示空栏目,char zuoyename; /已分配区表Struct free_table float address; /空闲分区起始地址float length; /空闲分区长度,单位为字节int flag; /空闲分区表登记栏
4、目用0表示空栏目,1表示未配; /空闲分区表第二,在设计的表格上进行内存分配l 首次适应算法:为作业分配内存,要求每次找到一个起始地址最小的适合作业的分区(按起始地址递增排序)。l 最大碎片size:要求当找到的空闲分区作业的大小的值小于或等于size时,将该分区全部分配给作业(数组后面元素向前移);l 否则,给作业分割出一部分空间时,其余部分仍作为新的空闲分区登记(空闲分区长度=空闲分区长度-作业长度,l 空闲分区起始地址=空闲分区起始地址+作业长度第三,在设计的表格上进行内存回收。1、上邻:条件:回收作业的始址=某个空闲区的始址+长度 操作:空闲区的长度=空闲区的长度+作业的大小2、下邻:
5、条件:回收作业的始址+作业的长度=某个空闲区的始址 操作: 空闲区的始址=回收作业的始址 空闲区的长度=空闲区的长度+作业的长度3、上下邻:条件:1,2条件同时成立 操作:空闲区的始址=上邻的始址 空闲区的长度=上邻的长度+作业的长度+下邻的长度 删除下邻4、无上下邻: 操作:找flag=0的行 空闲区的始址=回收作业的始址 空闲区的长度=作业的长度六、实验代码# include# include#define M 10 /允许的空闲区表长最大为m#define N 10 /允许的最大作业数量为n#define MIN 1 /碎片的最大值#define SADDRESS 200 /空闲分区初始
6、的起始地址#define SLENGTH /空闲分区的初始长度struct used_tfloat address; /已分分区起始地址float length; /已分分区长度int flag; /已分配表区登记栏标志,用0表示空栏目used_tableN;struct free_tfloat address; /空闲分区起始地址float length; /空闲分区长度int flag; /空闲分区表登记栏目用0表示空栏目,1表示未分配free_tableM; /空闲分区表void allocate(char,float); /分配算法子程序void reclaim(char); /回收算
7、法子程序void main()int i,a;float zyl; char zyn;/空闲分区表初始化free_table0.address=SADDRESS; /空闲分区表的起始地址free_table0.length=SLENGTH; /空闲分区表的长度 free_table0.flag=1; /标志位置1表示未分配for(i=1;iM;i+)free_tablei.address=0;free_tablei.length=0;free_tablei.flag=0; /0表示空栏目/已分分区表初始化 for(i=0;iN;i+)used_tablei.address=0;used_tab
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 计算机 操作系统 动态 分区 存储 管理 方式 内存空间 分配 回收 实验 报告
限制150内