大概看了一下在keil的内存动态分,它是用一个链表来实现的,用一个名为__mem_avail__的__mem__类型的结构数组来malloc,free内存的
struct __mem__
{
struct __mem__ _MALLOC_MEM_ *next; /* single-linked list */
unsigned int len; /* length of following block */
};
typedef struct __mem__ __memt__;
__memt__ _MALLOC_MEM_ __mem_avail__ [2] =
{
{ NULL, 0 }, /* HEAD for the available block list */
{ NULL, 0 }, /* UNUSED but necessary so free doesn't join HEAD or ROVER with the pool */
};
在默认情况下,keil中的mallloc分配的内存在XDATA这64K的空间里面的,感觉用起来实在太麻烦了,所以没有做过多的研究,
个人觉得用malloc不如用数组,虽然malloc是动态分配的,但是使用malloc和数组一样,在同一时刻,内存使用的总量不能超过
实际内存的大小,只要用足够大的数组就OK了。还有就是,在查看keil软件的lib目录时,没有发现内存清理的机制,就是说很可能出现内存碎片,减小内存利用率!所以还是数组比较好!!