boost的内存池实现了一个快速、紧凑的内存分配和管理器,使用它可以完全不用考虑delete释放问题。常用的boost内存池有pool、object_pool、singleton_pool。

1、pool

pool是一个简单的内存池类,它的模板类型通常使用默认的参数,构造函数的参数用来指定每次分配内存的大小,这个值可以通过成员get_requested_size()获得。
pool会根据需要自动向系统申请或归还使用的内存,在其析构的时候自动释放它持有的所有内存。常用的成员函数:

malloc():分配一块内存,返回类型为void*,内存分配失败返回NULL。
  ordered_malloc():分配一块内存并合并空闲块链表,不推荐使用该函数,因为其效率低。
  is_from():测试内存块是否属于本内存池。
  free():释放malloc()非配的内存,不建议调用该函数来手动释放内存,因为pool是自动管理内存分配的。
  release_memory():释放所有未被分配的内存。
  purge_memory():强制释放pool持有的所有内存。

简单使用示例:

#include <iostream>
using namespace std; #include "boost\pool\pool.hpp"
using namespace boost; int main()
{
pool<> p1(sizeof(int)); int* p = (int*)p1.malloc();
*p = ;
cout << *p << endl; return ;
}

 2、object_pool

object_pool是类实例的内存池,其模板类型的参数用来指定使用的类,其成员construct()用来分配一个类的对象,destroy()用来释放一个已分配的对象,is_from()用来测试对象是否属于本内存池分配的。

需要注意的三点:

①、默认情况下成员函数construct最多支持3个参数,可以对construct进行扩展以支持3个参数以上的构造函数,具体扩展方法可参见罗剑锋的《Boost程序库完全开发指南》一书。
   ②、object_pool的成员函数destroy()效率很低(原因可参考这篇文章http://blog.csdn.net/byxdaz/article/details/6153786),如果需要频繁释放已分配的对象的话谨慎考虑object_pool。
   ③、object_pool还提供了malloc()和free()成员,其可以像pool那样来分配和释放内存块。

简单实用示例:

#include <iostream>
#include <string>
using namespace std; #include "boost\pool\object_pool.hpp"
using namespace boost; int main()
{
object_pool<string> ops;
string* p = ops.construct("test");
cout << *p << endl; return ;
}

 3、singleton_pool

singleton_pool是pool的线程安全版本,它是单例模式的,用户不用创建它,它可以保证在main函数运行之前就创建了单例。singleton_pool的模板类型参数有两个,其中 第一个可以是一个空类,第二个与pool的模板参数意义相同。

简单实用示例:

#include <iostream>
#include <string>
using namespace std; #include "boost\pool\singleton_pool.hpp"
using namespace boost; struct pool_tag {};
typedef singleton_pool<pool_tag, sizeof(int)> slp;
int main()
{
int* p = (int*)slp::malloc();
*p = ;
cout << *p << endl; return ;
}

boost--内存池的更多相关文章

  1. 重写boost内存池

    最近在写游戏服务器网络模块的时候,需要用到内存池.大量玩家通过tcp连接到服务器,通过大量的消息包与服务器进行交互.因此要给每个tcp分配收发两块缓冲区.那么这缓冲区多大呢?通常游戏操作的消息包都很小 ...

  2. Boost内存池使用与测试

    目录 Boost内存池使用与测试 什么是内存池 内存池的应用场景 安装 内存池的特征 无内存泄露 申请的内存数组没有被填充 任何数组内存块的位置都和使用operator new[]分配的内存块位置一致 ...

  3. 基于C/S架构的3D对战网络游戏C++框架 _05搭建系统开发环境与Boost智能指针、内存池初步了解

    本系列博客主要是以对战游戏为背景介绍3D对战网络游戏常用的开发技术以及C++高级编程技巧,有了这些知识,就可以开发出中小型游戏项目或3D工业仿真项目. 笔者将分为以下三个部分向大家介绍(每日更新): ...

  4. boost的线程池和内存池 智能指针

    内存池为boost自带的 #include <boost/pool/pool.hpp> 或者另外一个开源的库: nedmalloc 一个高效率的库 线程池需要下载另外一个开源库 http: ...

  5. 定长内存池之BOOST::pool

    内存池可有效降低动态申请内存的次数,减少与内核态的交互,提升系统性能,减少内存碎片,增加内存空间使用率,避免内存泄漏的可能性,这么多的优点,没有理由不在系统中使用该技术. 内存池分类: 1.      ...

  6. boost之内存池

    讲到内存池我们会想到对对象进行动态分配的过程new包含三个过程 1.使用operator new分配内存 2.使用placement new 初始化 3.返回内存地址. 分配内存可以分解成分配内存和获 ...

  7. nginx——内存池篇

    nginx--内存池篇 一.内存池概述 内存池是在真正使用内存之前,预先申请分配一定数量的.大小相等(一般情况下)的内存块留作备用.当有新的内存需求时,就从内存池中分出一部分内存块,若内存块不够再继续 ...

  8. 不定长内存池之apr_pool

    内存池可有效降低动态申请内存的次数,减少与内核态的交互,提升系统性能,减少内存碎片,增加内存空间使用率,避免内存泄漏的可能性,这么多的优点,没有理由不在系统中使用该技术. 内存池分类: 1.      ...

  9. 初识nginx——内存池篇

    初识nginx——内存池篇 为了自身使用的方便,Nginx封装了很多有用的数据结构,比如ngx_str_t ,ngx_array_t, ngx_pool_t 等等,对于内存池,nginx设计的十分精炼 ...

  10. 常见C++内存池技术

    原文:http://www.cppblog.com/weiym/archive/2013/04/08/199238.html 总结下常见的C++内存池,以备以后查询.应该说没有一个内存池适合所有的情况 ...

随机推荐

  1. web应用 与 http协议

    一.web 应用 Web应用程序是一种可以通过Web访问的应用程序,用户只需要有浏览器即可访问应用程序,不需要再安装其他软件. 应用程序有两种模式C/S.B/S.C/S即客户端—服务端程序这类程序一般 ...

  2. python中class的序列化和反序列化

    对于类的序列化:将类的成员变量名和数据作为一对键值对存储在物理内存中,例如 class A(object): def __init__(self): self.a = o self.b = 1 sel ...

  3. 发布者订阅者模式之JAVA实现

        1.发布者接口 package com.shoshana.publishsubscribe; public interface IPublisher<M> { public voi ...

  4. 深入理解volatile

    volatile知识点 --------------------------------------------------------------------------- 1.volatile关键 ...

  5. [持续交付实践] pipeline使用:Multibranch Pipeline

    前言 在探讨multiBranch Pipeline之前,很有必要先探讨下如何制定有效的代码分支管理规范,使用高效的版本控制系统,并对构建产物及其依赖进行管理.我们首先要强调,需要进行版本控制的不仅是 ...

  6. linux 查看端口被占用

    linux 查看端口被占用 1.lsof  -i : 端口号 用于查看某一端口的占用情况,比如查看8080端口使用情况,lsof  -i:8080 如果执行 lsof  -i:8080 系统提示 :  ...

  7. Laravel数据库操作 Eloquent ORM

    模型首先在App目录下建立student的文件夹 里面放上 Student.php 且需要继承基类Model //允许批量赋值的字段// protected $fillable = ['name',' ...

  8. leetcode62

    使用排列组合计算公式来计算,注意使用long long型数据保证计算不会溢出. class Solution { public: int M, N; ; //从根到叶子有多少个分支,就表示有多少种路径 ...

  9. 编织织物的knit course direction and knit wale direction

    来自:http://www.definetextile.com/2013/04/course-wale.html

  10. DJango 基础(6)

    Django模型基础 知识点: 数据库的配置 使用django中的模型 将模型映射到数据库 数据的增删改查基本操作 数据库的配置 1.在settings.py中配置DATABASES: DATABAS ...