我正在尝试在 C 中构建一个内存分配器。用户首先说他想要使用多少内存,以及可以使用的最小内存块大小。
因此,例如,假设用户请求 1024B,最小块大小为 8B。这意味着可能的块大小为 1024、512、256、128、64、32、16 和 8。
为了跟踪空闲的内存块,我有一个指向结构的指针数组。这些结构称为 Header,数组称为 FreeList。我的意思是,FreeList[0] 将包含一个指向内存中内存大小为 8 块的空间的指针。 FreeList[1] 将包含一个指向内存中内存大小为 16 块的空间的指针。 ETC。
typedef void * Addr;
struct Header
{
Addr next;
int order;
};
struct Header *FreeList[];
我正在尝试为此空闲列表分配内存以与以下代码一起使用:
FreeList = malloc(Order*sizeof(struct Header));
其中 Order 是您可以拥有的不同块大小的数量。
我收到编译错误“FreeList”的类型不完整。
我不希望这些指针指向任何地方,我只想为数据分配空间。