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

Logo

魔乐社区(Modelers.cn) 是一个中立、公益的人工智能社区,提供人工智能工具、模型、数据的托管、展示与应用协同服务,为人工智能开发及爱好者搭建开放的学习交流平台。社区通过理事会方式运作,由全产业链共同建设、共同运营、共同享有,推动国产AI生态繁荣发展。

更多推荐