我正在为大学作业编写 malloc 函数。这是我的想法的基本布局:
1)定义一个节点结构,其中包含指向前一个节点、下一个节点的指针,以及一个用于大小和空缺的字符。堆中的每个区域都将包含一个带有此信息的隐藏节点。
2)malloc函数。从第一个节点循环开始,通过每个节点检查空缺。如果一个节点是空的并且足够大,则将一个 ptr 返回到不包括该节点的区域的开头。如果没有可用空间,请使用 sbrk 为节点分配请求的空间 PLUS 空间。
3)自由功能。转到作为参数sizeof(结构节点)传递的指针并将空缺设置为空缺。然后从列表的开头开始,遍历列表合并相邻的空闲空间。
这种方法听起来如何?我主要关心的是实际启动链表。例如,在开始进行任何分配并将 ptr 作为全局变量存储到它之前,是否应该使用 sbrk 创建一个节点?如果是这样,在允许驱动程序调用 malloc 函数之前如何初始化第一个节点?
提前致谢。我不是要求有人编写我的代码,只是为了提供一些关于我的想法的见解和建议。