初探boost之pool库学习笔记

pool

内存池概述

通常我们习惯直接使用new、malloc等API申请分配内存,这样做的缺点在于:由于所申请内存块的大小不定,当频繁使用时会造成大量的内存碎片并进而降低性能。

内存池则是在真正使用内存之前,先申请分配一定数量的、大小相等(一般情况下)的内存块留作备用。当有新的内存需求时,就从内存池中分出一部分内存块,若内存块不够再继续申请新的内存。这样做的一个显著优点是尽量避免了内存碎片,使得内存分配效率得到提升。

pool库概述

pool库实现了一个快速、紧凑的内存池库,不仅能够管理大量的对象,也可以作为STL的内存分配器,某种程度上它近似于一个小型的垃圾回收机制,在需要大量分配和释放小对象时,有很高的效率,而且完全不用考虑delete。

pool库包括4个组件:pool 、object_pool 、singleton_pool 、pool_alloc 。

pool

最简单、最易使用的内存池,返回一个简单数据类型的内存指针。

在头文件 #include<boost/pool/pool.hpp>

操作函数

用法

#include<iostream>
#include<boost/pool/pool.hpp>
using namespace std;
using namespace boost;

int main()
{
    pool<> rpool(sizeof(int));   //定义内存池 内存块大小以int为单位
    int *p = (int *)rpool.malloc();  //void* 转换为 int*
    rpool.free(p);  //释放
    return 0;
}

注:

pool在分配失败时不会抛出异常,实际编写代码时应该检查返回的时候是否为空。

object_pool

object_pool用于对象(类实例)的内存池。

使用时包含头文件#include<boost/pool/object_pool.hpp>

操作函数

用法

#include<iostream>
#include<boost/pool/object_pool.hpp>
using namespace std;
using namespace boost;

class class_type
{
public:
    int a;
    class_type(int _a = 0):a(_a){};
};

int main()
{
    object_pool<class_type> pl; // 定义这个类的内存池
    class_type * p = pl.malloc(); //调用malloc函数 返回一个类类型的内存块 初始化该类型的指针
    cout<<p->a;  //默认是0

    p = pl.construct(100); //构造一个新对象
    cout<<p->a;
    return 0;

}

singleton_pool

头文件#include<boost/pool/singleton_pool.hpp>

与pool接口完全一致

pool_alloc

头文件#include<boost/pool/pool_alloc.hpp>

提供了两个标准容器模版参数的内存分配器pool_alloc和fast_pool_allocator

用法

#include<iostream>
#include<boost/pool/pool_alloc.hpp>
#include<vector>
using namespace std;
using namespace boost;

int main()
{
    vector<int,pool_allocator<int> >  v;
    v.push_back(1);
    cout<<v.size();
    return 0;
}
时间: 2024-12-11 19:04:13

初探boost之pool库学习笔记的相关文章

初探boost之timer库学习笔记

timer 用法 #include <boost/timer.hpp> #include <iostream> using namespace std; using namespace boost; int main() { timer t;//声明一个计时器对象,开始计时 cout<<"max:"<<t.elapsed_max()/3600<<"h"<<endl; //可度量的最大时间,以小时

初探boost之progress_display库学习笔记

progress_display 用途 progress_display可以在控制台上显示程序的执行进度,如果程序执行很耗费时间,那么它能提供一个友好的用户界 面,不至于让用户在等待中失去耐心,甚至怀疑程序的运行是否出了问题. 用法示例 #include <boost/progress.hpp> #include <iostream> #include <vector> using namespace std; using namespace boost; int ma

初探boost之smart_ptr库学习笔记

概述 Boost.smart_ptr库提供了六种智能指针,除了shared_ptr 和 weak_ptr 以外还包括 scoped_ptr .scoped_array . shared_array .intrusive_ptr .他们的速度与原始指针相差无几,都是异常安全的,而且对于类型T也仅有一个要 求:类型T的析构函数不能抛出异常. 使用时包含头文件: #include<boost/smart_ptr.hpp> scoped_ptr 用法: scoped_ptr 的构造函数接受一个类型为T

初步boost之pool图书馆学习笔记

pool 内存池概述 通常我们习惯直接使用new.malloc等API申请分配内存,这样做的缺点在于:因为所申请内存块的大小不定.当频繁使用时会造成大量的内存碎片并进而减少性能. 内存池则是在真正使用内存之前,先申请分配一定数量的.大小相等(普通情况下)的内存块留作备用.当有新的内存需求时.就从内存池中分出一部分内存块,若内存块不够再继续申请新的内存. 这样做的一个显著长处是尽量避免了内存碎片.使得内存分配效率得到提升. pool库概述 pool库实现了一个高速.紧凑的内存池库,不仅可以管理大量

0806------Linux网络编程----------Echo 网络库 学习笔记

1.Echo网络库的编写 1.1 Echo网络库1.0 1.1.1 Echo网络库 1.0 框架分析 a)class InetAddress: 主要用来定义一个struct sockaddr_in 结构(用自定义端口号初始化),并提供获取这个结构体成员如IP.Port等的接口: b)class Socket : 主要用来把一个普通的 sockfd 变为 listenfd(这里用一个sockfd初始化对象),提供bind .listen.accept 等接口. c)class TcpConnect

Java 8 流库学习笔记(一)

[core Java学习笔记]Java SE8 流库 Stream Library 从迭代到流 如果要计算一个文本中有多少长单词(字母>12). 迭代式: words = getlist();//虚构方法,获得一个List<String> long count = 0; for(String w:words) { if(w.length()>12) count++; } 流式: words = getlist();//虚构方法,获得一个List<String> long

Lufylegend库学习笔记1 绘图操作及鼠标事件

这几天对于网页前端有点兴趣,学习了一下Canvas的相关知识. 看到Lufylegend库之后,感觉很棒,有一种在写AS的感觉.今天入门第一站,写了一个画板. 是一个非常简易的画板,但是可以看到一些重要的思想. 代码如下: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Mouse Event</title&g

GDAL库学习笔记(1):无缝拼接Google卫星图

开工之前要先了解一下瓦片地图,瓦片地图金字塔模型是一种多分辨率层次模型,从瓦片金字塔的底层到顶层,分辨率越来越低,但表示的地理范围不变.实现原理就是,首先确定地图服务平台所要提供的缩放级别的数量N,把缩放级别最低.地图比例尺最大的地图图片作为金字塔的底层,即第0层,并对其进行分块,从地图图片的左上角开始,从左至右.从上到下进行切割,分割成相同大小(比如256x256像素)的正方形地图瓦片,形成第0层瓦片矩阵;在第O层地图图片的基础上,按每2x2像素合成为一个像素的方法生成第1层地图图片,并对其进

Libevent库学习笔记

Libevent是一个事件触发的网络库,适用于windows.linux.bsd等多种平台,Libevent在底层select.pool.kqueue和epoll等机制基础上,封装出一致的事件接口.可以注册可读.可写.超时等事件,指定回调函数:当事件发生后,Libevent调用回调函数,可以在回调函数里实现自定义功能.编译库代码,编译脚本会判断OS支持哪种类型的事件机制(select.epoll或kqueue),然后条件编译相应代码,供上层使用的接口仍然是保持统一的. 著名分布式缓存软件memc