boost学习笔记(pool)

智能指针解决了内存泄露的问题,但是有一个问题没有解决,那就是频繁的new/delete将造成很多内存碎片,影响程序效率。为了解决这个问题内存池出现了,内存池就相当于一个小的垃圾回收机制,在需要大量的分配释放小对象时很有效率,而且完全不需要考虑delete。
boost提供的内存池:pool,object_pool,singleton_pool。

pool

需要头文件:boost\pool\pool.hpp
只能作为基本类型如int,double等的内存池。malloc方法进行分配内存。free方法用于手动释放之前分配的内存,一般不需要调用free方法,除非你觉得内存池空间不足,必须释放。

pool<> pl(sizeof(int));
int *p = static_cast<int*>(pl.malloc());
*p = 100;
cout << *p << endl;
pl.free(p);//手动释放,

object_pool

需要头文件:boost\pool\object_pool.hpp
应用于对象的内存池,可以调用对象的构造函数。

class User {
public:
    int age;
    User(int a = 20) : age(a) {}
};
int main() {

    object_pool<User> opl;
    User *u = opl.malloc();
    cout << u->age << endl;//没有初始化,不可预期的值
    User *u1 = opl.construct();//调用构造方法初始化
    cout << u1->age << endl;//10
    opl.free(u);
}

singleton_pool

需要头文件:boost\pool\singleton_pool.hpp
和pool类似,用于基本类型的内存池,区别是它是单件且线程安全的。

typedef singleton_pool<User, sizeof(int)> spl;
int *pi = static_cast<int*>(spl::malloc());
*pi = 100;
cout << *pi << endl;

猜你喜欢

转载自blog.csdn.net/maosijunzi/article/details/80776067