- 1、本文档共10页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
计算机操作系统动态分区存储管理方式下的内存空间的分配与回收实验报告
计算机操作系统
实验报告
实验二
实验题目:存储器管理
系别:计算机科学与技术系
班级:
姓名:
学号:2
一实验目的
确定用来管理内存当前使用情况的数据结构;
采用首次适应算法完成内存空间的分配;
分情况对作业进行回收;
编写主函数对所做工作进行测试。
三、实验原理
分配:动态分区存储管理方式把内存除OS占用区域外的空间看作一个大的空闲区。当作业要求装入内存时,根据作业需要内存空间的大小查询内存中各个空闲区,当从内存中找到一个大于或等于该作业大小的内存空闲区时,选择其中一个空闲区,按作业要求划出一个分区装入该作业。
回收:作业执行完后,它所占用的内存空间被收回,成为一个空闲区。如果该空闲区的相邻分区也是空闲区,则需要将相邻空闲区合并成一个空闲区。
四、实验方法
实现动态分区的分配与回收,主要考虑三个问题:
第一、设计记录内存使用情况的数据表格,用来记录空闲区和作业占用的区域(利用结构体类型数组来保存数据);
第二、在设计的数据表格基础上设计内存分配算法(采用首次适应算法找合适的分区(对空闲分区表进行排序),分配时要考虑碎片问题);
第三、在设计的数据表格基础上设计内存回收算法(分四种情况进行回收(上邻、下邻、上下邻和无相邻分区)。
五、实验步骤
第一,设计记录内存使用情况的数据表格
已分配分区表:起始地址、长度、标志(0表示“空表项”,1表示“已分配”)
空闲分区表: 起始地址、长度、标志(0表示“空表项”,1表示“未分配”)
struct used_table {
float address; //已分分区起始地址
float length; //已分分区长度,单位为字节
int flag; //已分配表区登记栏标志,用0表示空栏目,
char zuoyename;
}; //已分配区表
Struct free_table[ {
float address; //空闲分区起始地址
float length; //空闲分区长度,单位为字节
int flag; //空闲分区表登记栏目用0表示空栏目,1表示未配
}; //空闲分区表
第二,在设计的表格上进行内存分配
首次适应算法:为作业分配内存,要求每次找到一个起始地址最小的适合作业的分区(按起始地址递增排序)。
最大碎片size:要求当找到的空闲分区-作业的大小的值小于或等于size时,将该分区全部分配给作业(数组后面元素向前移);
否则,给作业分割出一部分空间时,其余部分仍作为新的空闲分区登记(空闲分区长度=空闲分区长度-作业长度,
空闲分区起始地址=空闲分区起始地址+作业长度
第三,在设计的表格上进行内存回收。
1、上邻:条件:回收作业的始址=某个空闲区的始址+长度
操作:空闲区的长度=空闲区的长度+作业的大小
2、下邻:条件:回收作业的始址+作业的长度=某个空闲区的始址
操作: 空闲区的始址=回收作业的始址
空闲区的长度=空闲区的长度+作业的长度
3、上下邻:条件:1,2条件同时成立
操作:空闲区的始址=上邻的始址
空闲区的长度=上邻的长度+作业的长度+下邻的长度
删除下邻
4、无上下邻:
操作:找flag=0的行
空闲区的始址=回收作业的始址
空闲区的长度=作业的长度
六、实验代码
# includeiostream.h
# includeiomanip.h
#define M 10 //允许的空闲区表长最大为m
#define N 10 //允许的最大作业数量为n
#define MIN 1 //碎片的最大值
#define SADDRESS 200 //空闲分区初始的起始地址
#define SLENGTH 150000 //空闲分区的初始长度
struct used_t{
float address; //已分分区起始地址
float length; //已分分区长度
文档评论(0)