定义管理空闲分区的相关数据结构:采用空闲分区链表来管理系统中所有的空闲分区,链表中的每个节点表示一个空闲分区,登记有空闲分区的起始地址和长度。
定义一个简单的进程控制块,其中有对应进程分配到的内存的起始地址和长度、以及进程的状态信息。当提交一个作业申请内存的要求时,便为该作业创建一个进程(此时,需要分配给它一个进程控制块以及它需要的内存空间)。简单起见,进程控制块用一个数组来实现,分配给作业n的进程控制块为其中第n个元素;而状态信息中执行和就绪表示为一种状态,忽略阻塞状态。
实现首次适应算法的内存分配函数alloc_mem(int len),其中的参数为所申请的内存空间的长度,函数返回值为所分配到的内存空间的起始地址,分配时优先将空闲区的低端部分分配出去,如果空闲区较大,则留下的高端部分仍为空闲区;实现回收内存的函数free_mem(int base, int len),其中的参数为回收区的起始地址和长度,回收时要求进行空闲分区的合并。
在main()中通过一些具体的分配和回收动作来测试上述内存分配和回收的函数,每完成一个动作,要求将进程的详细信息和所有空闲分区的详细信息显示出来。
1