当前位置:文档之家› 存储器管理实验报告.docx

存储器管理实验报告.docx

二、实验内容
用C语言分别实现采用首次适应算法和最佳适应算法的动态分区分配过程alloc()和回收过程free()。其中,空闲分区通过分区链来管理,在进行内存分配时,系统优先使用空闲区低端的空间。
请分别用首次适应算法和最佳适应算法进行内存块的分配和回收,要求每次分配和回收后显示出空闲内存分区链的情况。
{
ElemType data;
struct DuLNode *prior; //前趋指针
struct DuLNode *next; //后继指针
}DuLNode,*DuLinkList;
算法;
首次适应算法:是在分配内存时,从链首开始顺序查找,直到找到一个大小能够满足要求的分区,即进行分配。
最佳适应算法:是在分配内存时,从链首开始顺序查表,查找到链尾,并记录一个大小不小于要求的分区的最小分区,在查找完毕后进行分配。
{
return (*(struct kongxian *)a).start-(*(struct kongxian *)b).start;
}
int cmp2(const void *a,const void *b)
{
return (*(struct zuoye *)a).start-(*(struct zuoye *)b).start;
操作系统实验报告
存储器管理
学院电信学院
专业计算机科学与技术
班级14级计科一班
实验题目动态分区分配
实验组别第三组
指导老师曹华
学号
20141030111
20141030112
20141030113
20141030114
姓名
张 丹
陈云云
张伟军
李瑞玲
实验项目

题 目
动态分区分配
一、实验目的
了解动态分区分配方式中使用的数据结构和分配算法,并进一步加深对动态分区存储管理方式及其实现过程的理解。
(1)回收区与插入点的前一个空闲区F1相邻接,此时可将回收区直接与F1合并,并修改F1的大小;
(2)回收区与插入点的后一个空闲分区F2相邻接,此时可将回收区直接与F2合并,并用回收区的首址作为新空闲区的首址,大小为二者之和;
(3)回收区同时与插入点的前后两个空闲分区邻接,此时需将三者合并;
(4)回收区不与任何一个空闲区邻接,此时应建一新的表项
printf("空闲分区ID:%d起止:%d结束:%d长度:%d\n",i,kongxian[i].start,kongxian[i].end,kongxian[i].length);
}
void print2() //打印作业分区
{
int i;
for(i=0;i<n2;i++)
printf("作业分区ID:%d起止:%d结束:%d长度:%d\n",i,zuoye[i].start,zuoye[i].end,zuoye[i].length);
内存回收:将释放作业所在内存块的状态改为空闲状态,删除其作业名,设置为空,并判断该空闲块是否与其他空闲块相连,若释放的内存空间与空闲块相连时,则合并为同一个空闲块,同时修改分区大小及起始地址。
每当一个进程被创建时,内存分配程序首先要查找空闲内存分区链,从中寻找一个合适的空闲块进行划分,并修改空闲内存分区链,系统根据回收区的首址,从空闲区链中找到相应的插入点,此时出现如下四种情况:
三、实验要仪器设备
软件环境:VC++6编程环境
四、实验原理及设计方案
1.实验原理:
可变分区调度算法有:最先适应分配算法,循环首次适应算法,最佳适应算法,最坏适应算法。
首次适应算法(First-fit):当要分配内存空间时,就查表,在各空闲区中查找满足大小要求的可用块。只要找到第一个足以满足要求的空闲块就停止查找,并把它分配出去;如果该空闲空间与所需空间大小一样,则从空闲表中取消该项;如果还有剩余,则余下的部分仍留在空闲表中,但应修改区分大小和分区始址。
struct kongxian
{
int start; //起址
int end; //结束
int length; //长度
}kongxian[N];
struct zuoye
{
int start; //起址
int end; //结束
int length; //长度
}zuoye[N];
int cmp1(const void *a,const void *b)
2.主要数据结构的说明
定义一个空闲区说明表结构
struct freearea {
int ID; //分区号
long size; //分区大小
long address; //分区地址
int state; //状态
}ElemType;
线性表的双向链表存储结构
Struct DuLNode//double linked list
}
void init()
{
n1=1; //初始时只有一个空闲区
n2=0; //初始没有作业
kongxian[0].start=0;
kongxian[0].end=1023;
kongxian[0].length=1024;
}
void print1() //打印空闲分区
{
int i;
for(i=0;i<n1;i++)
3.程序流程图
首次适应算法
最佳适应算法
F
T
TF
4.实验程序
首次适应算法
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#include<math.h>
#define N 10000
int n1;//空闲分区的个数
int n2;//作业区的个数
}
int main()
{
int i,j,t,len,flag,id;
int front,middle, behind;
int t1,t2;
init();
print1();
printf("输入1装入新作业,输入0回收作业,输入-1结束\n");
用户提出内存空间的申请:系统根据申请者的要求,按照一定的分配策略分析内存空间的使用情况,找出能满足请求的空闲区,分给申请者;当程序执行完毕或主动归还内存资源时,系统要收回它所占用的内存空间或它归还的部分内存空间。
最佳适应算法(Best-fit):当要分配内存空间时,就查找空闲表中满足要求的空闲块,并使得剩余块是最小的。然后把它分配出去,若大小恰好合适,则直按分配;若有剩余块,则仍保留该余下的空闲分区,并修改分区大小的起始地址。
相关主题