可变分区存储管理

本文档描述了一个C语言编程实验,旨在模拟UNIX可变分区内存管理。实验要求实现分配函数lmalloc和释放函数lfree,使用循环首次适应法,并提供结构数组或双向链接表两种数据结构选项。实验还包括输入输出处理,以及详细的测试和错误处理方案。
摘要由CSDN通过智能技术生成

实验一 可变分区存储管理

(一)      实验题目

编写一个C程序,用char *malloc(unsigned size)函数向系统申请一次内存空间(如size=1000,单位为字节),用循环首次适应法

addr = (char *)lmalloc(unsigned size)

lfree(unsigned size,char * addr)模拟UNIX可变分区内存管理,实现对该内存区的分配和释放管理。

 

(二)      实验目的

1.加深对可变分区的存储管理的理解;

2.提高用C语言编制大型系统程序的能力,特别是掌握C语言编程的难点:指针和指针作为函数参数;

3.掌握用指针实现链表和在链表上的基本操作。

 

(三)      实验要求

要分配函数lmalloc的参数size和释放函数lfree的参数sizeaddr以键盘命令的形式输入,每次分配和释放后显示自己的空闲存储区表。

空闲存储区表可采用结构数组的形式(基本要求)或双向链接表的形式(提高一步),建议采用的数据结构为:

结构数组的形式:

struct map {

   unsigned m_size;

   char * m_addr;

};

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值