为什么要使用内存池(why)?
我们知道,在使用c语言开发程序时,进程会对内存进行动态的分配和释放,那么,如果在一个程序里频繁的分配和释放内存会带来两点不好的结果:
(1)频繁分配和释放内存会进行多次系统调用,增加系统开销,影响程序效率;
(2)频繁分配和释放内存会产生许多内存碎片,降低内存的使用率,降低内存分配的效率;
因此,为了解决上述两点弊端,我们在开发程序时,如果需要频繁地分配使用内存,可以采用内存池的方法,降低内存分配和释放的开销.
内存池使用的API介绍
pool_t _pool_new_heap(int size);//创建大小为size的新的内存池。
void *pool_malloc(pool_t, int size);// 从指定内存池中分配大小为size的内存空间,这些空间会在内存池释放时,被自动的释放。
int pool_size(pool_t p);//内存池的大小,返回内存池中所有内存块的大小总和
void pool_free(pool_t p);//释放内存池,这会导致所有内存被释放,同时内存池本身也被释放
。。。 。。。
与内存池相关的数据结构
具体的实现见blog: http://blog.csdn.net/chdhust/article/details/8773144