c语言内存池介绍与应用

来源:互联网 发布:线材下料优化软件 编辑:程序博客网 时间:2024/06/05 01:59

为什么要使用内存池(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

原创粉丝点击