mirror of
https://gitee.com/acl-dev/acl.git
synced 2024-12-15 09:20:52 +08:00
79 lines
1.8 KiB
C++
79 lines
1.8 KiB
C++
#pragma once
|
|
#include "acl_cpp/acl_cpp_define.hpp"
|
|
|
|
struct ACL_DBUF_POOL;
|
|
|
|
namespace acl
|
|
{
|
|
|
|
/**
|
|
* 内存链管理类,该类仅提供内存分配函数,在整个类对象被析构时该内存链会被一次性地释放,
|
|
* 该类适合于需要频繁分配一些大小不等的小内存的应用;
|
|
* 该类实际上是封装了 lib_acl 中的 ACL_DBUF_POOL 结构及方法
|
|
*/
|
|
class ACL_CPP_API dbuf_pool
|
|
{
|
|
public:
|
|
/**
|
|
* 该类对象必须动态创建
|
|
*/
|
|
dbuf_pool();
|
|
|
|
/**
|
|
* 该类对象必须要动态创建,所以隐藏了析构函数,使用者需要调用 destroy
|
|
* 函数来销毁动态对象
|
|
*/
|
|
void destroy();
|
|
|
|
/**
|
|
* 重载了 new/delete 操作符,在 new dbuf_pool 对象时,使之创建在内存池上,
|
|
* 从而减少了 malloc/free 的次数
|
|
*/
|
|
void *operator new(size_t size);
|
|
void operator delete(void* ptr);
|
|
|
|
/**
|
|
* 重置内存池的状态以便于重复使用该内存池对象
|
|
*/
|
|
void dbuf_reset();
|
|
|
|
/**
|
|
* 分配指定长度的内存
|
|
* @param len {size_t} 需要分配的内存长度,当内存比较小时(小于构造函数中的
|
|
* block_size)时,所分配的内存是在 dbuf_pool 所管理的内存链上,当内存较大时
|
|
* 会直接使用 malloc 进行分配
|
|
* @return {void*} 新分配的内存地址
|
|
*/
|
|
void* dbuf_alloc(size_t len);
|
|
|
|
/**
|
|
* 分配指定长度的内存并将内存区域清零
|
|
* @param len {size_t} 需要分配的内存长度
|
|
* @return {void*} 新分配的内存地址
|
|
*/
|
|
void* dbuf_calloc(size_t len);
|
|
|
|
/**
|
|
* 根据输入的字符串动态创建新的内存并将字符串内存进行复制,类似于 strdup
|
|
* @param s {const char*} 源字符串
|
|
* @return {char*} 新复制的字符串地址
|
|
*/
|
|
char* dbuf_strdup(const char* s);
|
|
|
|
/**
|
|
* 根据输入的内存数据动态创建内存并将数据进行复制
|
|
* @param s {const void*} 源数据内存地址
|
|
* @param len {size_t} 源数据长度
|
|
* @return {void*} 新复制的数据地址
|
|
*/
|
|
void* dbuf_memdup(const void* s, size_t len);
|
|
|
|
private:
|
|
ACL_DBUF_POOL* pool_;
|
|
size_t mysize_;
|
|
|
|
~dbuf_pool();
|
|
};
|
|
|
|
} // namespace acl
|