当前位置:首页 > 存储管理实验报告(操作系统)
实 验 报 告
课程名称: 操作系统
成 绩: 实验项目名称: 存储管理 实验时间: 20120504
指导教师(签名): 班级: 姓名: 学号:
实 验 目 的: 理解可变分区管理方式下采用最佳适应分配算法实现主存分配和回收。
对理论课中学习的内存管理中的概念作进一步的理解。
实 验 环 境:winTC
实 验 内 容 及 过 程: 1、分配主存
采用最佳适应分配算法(Best fit),将空闲区表中的空闲区按其容量递增的次序排列。当一个作业要求装入主存时,按由小到大的顺序查找空闲区说明表,找到第一个满足申请长度的空闲区(满足条件的最小空闲区)。有时候空闲区大于作业需要量,需要将空闲区分成两部分,一部分作业占用,另一部分作为一个空闲区将其插入适当的位置。为了方便查找,总是让“空表目”集中在表格的后面。
2、回收主存
当一个作业执行结束撤离时,作业所占的区域应该归还,系统根据回收区的首址从空闲区表中找到相应的插入点,归还的区域如果与其他空闲区相邻(有如下三种情况),则应合成一个大的空闲区,病登记在空闲区说明表中。否则作为一个新的空闲区登记在空闲区说明表中。 实验过程:
1. 编写程序,由必要的数据结构、主函数、内存分配函数及主存回收函数构成。实现可变分区管理
方式下采用最优/佳适应分配算法实现主存的分配和回收。 2. 在上机环境中输入程序,调试,编译。 3. 设计输入数据,写出程序的执行结果。
第 1 页 共 7 页
实 验 结 果 及 分 析: 程序a请求长度为10内存:
作业b请求长度为20的内存:
回收作业a主存
第 2 页 共 7 页
回收b 的主存:
实 验 心 得:
陈少琼:可变分区管理方式下采用最佳适应分配算法实现主存分配和回收是一个较好理解的算法,用C语言编写的参考程序要自己去补充定义,分析程序,理解算法,才可能去设计实验数据,进行实验,虽然会话多一点的时间,但是可以充分理解这个算法,和计算机主存的分配和回收情况。
兰晓铃:本实验的实验过程中还是遇到比较多的问题,程序编译时不能够一次通过,而是要不断的补充和定义,课堂上的最佳适应算法虽然通俗易懂,但要用这样基础的程序语言描述出来,并且编译通过还有相当大的距离,在老师和同学的帮助下终于实现可变分区管理方式下采用最优/佳适应分配算法实现主存的分配和回收。 附 录:
运行程序: #include \#include \#define m 5 #define n 5 #define minisize 1 struct { float address; float length; int flag; } free_table[m]; struct { float address; float length; int flag; }used_table[n];
第 3 页 共 7 页
allocate(char job,float xk) { int i,k; float ad; k=-1;
for(i=0;i<=m;i++)
if(free_table[i].length>=xk && free_table[i].flag==1) /*找到足够大,未分配的空闲区*/ if(k==-1 || free_table[i].length printf(\ return; } if(free_table[k].length-xk<=minisize) /*直接分配*/ { free_table[k].flag=0; /*标记为已分配*/ ad=free_table[k].address; xk=free_table[k].length; } else { free_table[k].length=free_table[k].length-xk; /*分配分割*/ ad=free_table[k].address+free_table[k].length; } i=0; while(used_table[i].flag!=0 &&i printf(\ if(free_table[k].flag==0) free_table[k].flag=1; else{ free_table[k].length=free_table[k].length+xk; return; } } else{ used_table[i].address=ad; used_table[i].length=xk; used_table[i].flag=job; } return; } reclaim(char job) { 第 4 页 共 7 页
共分享92篇相关文档