boost--内存池
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--内存池的更多相关文章
- 重写boost内存池
最近在写游戏服务器网络模块的时候,需要用到内存池.大量玩家通过tcp连接到服务器,通过大量的消息包与服务器进行交互.因此要给每个tcp分配收发两块缓冲区.那么这缓冲区多大呢?通常游戏操作的消息包都很小 ...
- Boost内存池使用与测试
目录 Boost内存池使用与测试 什么是内存池 内存池的应用场景 安装 内存池的特征 无内存泄露 申请的内存数组没有被填充 任何数组内存块的位置都和使用operator new[]分配的内存块位置一致 ...
- 基于C/S架构的3D对战网络游戏C++框架_05搭建系统开发环境与Boost智能指针、内存池初步了解
本系列博客主要是以对战游戏为背景介绍3D对战网络游戏常用的开发技术以及C++高级编程技巧,有了这些知识,就可以开发出中小型游戏项目或3D工业仿真项目. 笔者将分为以下三个部分向大家介绍(每日更新): ...
- boost的线程池和内存池 智能指针
内存池为boost自带的 #include <boost/pool/pool.hpp> 或者另外一个开源的库: nedmalloc 一个高效率的库 线程池需要下载另外一个开源库 http: ...
- 定长内存池之BOOST::pool
内存池可有效降低动态申请内存的次数,减少与内核态的交互,提升系统性能,减少内存碎片,增加内存空间使用率,避免内存泄漏的可能性,这么多的优点,没有理由不在系统中使用该技术. 内存池分类: 1. ...
- boost之内存池
讲到内存池我们会想到对对象进行动态分配的过程new包含三个过程 1.使用operator new分配内存 2.使用placement new 初始化 3.返回内存地址. 分配内存可以分解成分配内存和获 ...
- nginx——内存池篇
nginx--内存池篇 一.内存池概述 内存池是在真正使用内存之前,预先申请分配一定数量的.大小相等(一般情况下)的内存块留作备用.当有新的内存需求时,就从内存池中分出一部分内存块,若内存块不够再继续 ...
- 不定长内存池之apr_pool
内存池可有效降低动态申请内存的次数,减少与内核态的交互,提升系统性能,减少内存碎片,增加内存空间使用率,避免内存泄漏的可能性,这么多的优点,没有理由不在系统中使用该技术. 内存池分类: 1. ...
- 初识nginx——内存池篇
初识nginx——内存池篇 为了自身使用的方便,Nginx封装了很多有用的数据结构,比如ngx_str_t ,ngx_array_t, ngx_pool_t 等等,对于内存池,nginx设计的十分精炼 ...
- 常见C++内存池技术
原文:http://www.cppblog.com/weiym/archive/2013/04/08/199238.html 总结下常见的C++内存池,以备以后查询.应该说没有一个内存池适合所有的情况 ...
随机推荐
- redis持久化 (rdb
RDB(快照持久化) RDB(redis database),可以理解为快照/内存快照,RDB持久化过程是将当前进程中的数据生成快照存储到硬盘中 触发机制RDB持久化的触发机制分为两种,手动触发和自动 ...
- javac编译错误: 编码UTF8/GBK的不可映射字符
转自:https://blog.csdn.net/leytton/article/details/52740171 Linux下为UTF-8编码,javac编译gbk编码的java文件时,容易出现“错 ...
- Java 就业班 Web框架
- 尚硅谷springboot学习30-docker安装mysql示例
docker pull mysql 错误的启动示例 错误日志:需要设置密码 正确的启动 但还不能直接使用,因为没有做端口映射,外界无法连接 可用的启动 连接成功 几个高级的操作 指定配置文件 dock ...
- 从零开始搭建自己的VueJS2.0+ElementUI单页面网站(一、环境搭建)
原网址:https://blog.csdn.net/u012907049/article/details/72764151 前言 VueJS可以说是近些年来最火的前端框架之一,越来越多的网站开始使用v ...
- Pushlet实现后台信息推送(一)
Pushlet是使用较多的后台向前台推送信息的工具.前台订阅某个感兴趣的事件joinListen,触发后台的Pushlet的servlet,为该请求会话建立session,默认这个sessionID是 ...
- MyBatis :Insert (返回主键、批量插入)
一.前言 数据库操作怎能少了INSERT操作呢?下面记录MyBatis关于INSERT操作的笔记,以便日后查阅. 二.insert元素 属性详解 其属性如下: parameterType , ...
- 2019南昌网络赛-M(二分)
题目链接:https://nanti.jisuanke.com/t/38232 题意:给定字符串s(长度<=1e5),然后N组样例(N<=1e5),每组输入一个字符串t判断t是否为s的字串 ...
- vue项目如何通过前端实现自动识别并配置服务器环境地址
前言: 一般来说,一个web项目的生产环境和测试环境的服务器地址一旦确定下来,很少会频繁变动的.那么就可以单独写一个脚本文件,通过当前访问的域名来判断当前的访问环境,然后再通过一定的规则获取对应的服务 ...
- pythone函数基础(9)操作数据库连接
#操作数据库连接import pymysqlconn = pymysql.connect(host='118.24.3.40',user='jxz', password='123456',port=3 ...