超级好用的C++实用库之环形内存池

💡 需要该C++实用库源码的大佬们,可搜索微信公众号"希望睿智"。添加关注后,输入消息"超级好用的C++实用库",即可获得源码的下载链接。

概述

环形内存池是一种高效的内存管理技术,特别适合于高并发、实时性要求高的系统中,比如:网络服务器、游戏引擎、实时音视频等领域。它的设计基于环形缓冲区的概念,通过循环利用内存空间来减少内存碎片和分配效率问题。环形内存池一次性申请大块内存,并切分为固定大小的内存块,避免了频繁的系统级内存请求,降低了系统调用开销。

CHP_FifoMemPool

为了方便环形内存池的使用,我们封装了CHP_FifoMemPool类。CHP_FifoMemPool是先分配先释放的环形内存池,适用于内存池的总大小相对固定的场景。一般会结合队列使用,应用层需保证先分配的内存先释放。使用CHP_FifoMemPool时,默认会加锁,以确保多线程环境下的资源安全。如果应用层需要对CHP_FifoMemPool和相关的队列一起加锁,则CHP_FifoMemPool初始化时可以不用加锁。

CHP_FifoMemPool类的头文件,可参考下面的示例代码。

cpp 复制代码
#pragma once

#include <map>

#include "HP_Mutex.h"

class CHP_FifoMemPool
{
public:
        CHP_FifoMemPool();
        ~CHP_FifoMemPool();

        int Init(unsigned int uiTotalBytes, bool bNeedLock = true);

        char *Alloc(unsigned int uiBytes);

        void Release(char *pBuf);
        
        void Reset();

private:
        typedef std::map<char *, unsigned int> MemToLenMap;

        unsigned int m_uiTotalBytes;
        bool m_bNeedLock;
        char *m_pMemStart;
        char *m_pMemEnd;
        char *m_pFreeStart;
        char *m_pFreeEnd;
        char *m_pReleaseEnd;
        char *m_pRemainStart;
        CHP_Mutex m_mutexMem;
        MemToLenMap m_mapMemToLen;
};

下面,我们逐个介绍CHP_FifoMemPool类导出的公共接口。

Init:初始化内存池。参数uiTotalBytes为内存池的最大字节数,参数bNeedLock表示是否需要加锁,默认加锁。返回值为0表示成功,其他为错误码。

Alloc:分配指定大小的buffer。参数uiBytes为buffer的大小,单位为字节。返回非NULL表示成功,否则失败。

Release:释放buffer。参数pBuf为之前分配的的buffer指针。

Reset:重置内存池,需要确保应用层不再使用已分配的buffer。

总结

环形内存池的设计有效提高了内存分配和回收的效率,特别适合于那些内存分配模式可预测、频繁分配和释放小块内存的场景。在高性能网络、实时系统、游戏引擎等领域,环形内存池展现出显著优势,通过减少内存管理开销和提高内存使用效率,为应用带来更高的响应速度和吞吐量。

相关推荐
要做朋鱼燕4 分钟前
【C++】 priority_queue 容器模拟实现解析
开发语言·c++·笔记·职场和发展
励志不掉头发的内向程序员10 分钟前
C++进阶——继承 (1)
开发语言·c++·学习
mit6.8242 小时前
并查集|栈
c++
中国胖子风清扬2 小时前
Rust 序列化技术全解析:从基础到实战
开发语言·c++·spring boot·vscode·后端·中间件·rust
岁忧3 小时前
(LeetCode 面试经典 150 题) 200. 岛屿数量(深度优先搜索dfs || 广度优先搜索bfs)
java·c++·leetcode·面试·go·深度优先
一枝小雨3 小时前
【OJ】C++ vector类OJ题
数据结构·c++·算法·leetcode·oj题
一枝小雨3 小时前
【C++】Vector完全指南:动态数组高效使用
开发语言·c++·笔记·vector·学习笔记·std库
buyutang_4 小时前
C/C++ Linux系统编程:线程控制详解,从线程创建到线程终止
linux·c语言·c++·学习
Qiang_san4 小时前
GNU Make | C/C++项目自动构建入门
c语言·c++·gnu
源代码•宸5 小时前
Leetcode—2749. 得到整数零需要执行的最少操作数【中等】(__builtin_popcountl)
c++·经验分享·算法·leetcode·位运算