好非主流的内存池用法,参考了某大牛的写法改造了一下。

namespace DL
{

template<typename T, typename MUTEX = DL::MutexLock, typename ALLOC = DL::QS::Allocator<T> >
class Memory
{
public:

        static void *operator new(size_t size);
        static void operator delete(void *ptr);
private:

        static MUTEX __mutex;
        static ALLOC __allocator;
};

template<typename T, typename MUTEX, typename ALLOC>
MUTEX Memory<T, MUTEX, ALLOC>::__mutex;

template<typename T, typename MUTEX, typename ALLOC>
ALLOC Memory<T, MUTEX, ALLOC>::__allocator(32);

template<typename T, typename MUTEX, typename ALLOC>
void *Memory<T, MUTEX, ALLOC>::operator new(size_t size)
{
        MutexLockGuard<MUTEX> lock(__mutex);
        assert(size == sizeof(T) && size >= 8);
        void *ptr = __allocator.malloc();
        return ptr;
}

template<typename T, typename MUTEX, typename ALLOC>
void Memory<T, MUTEX, ALLOC>::operator delete(void *ptr)
{
        MutexLockGuard<MUTEX> lock(__mutex);
        assert(ptr != NULL);
        __allocator.free(ptr);
}
}
用template方式让Memory变得可配置,若要加锁,用默认的DL::MutexLock,若不加锁用DL::NullLock,而内存配置策略也彩用template方式,这用内存配置方法也可以配置。

要想让类从内存池里拿来出来,就把你的类继承于Memory,如下。

#ifdef MEMROY
#ifdef ACE
#define MEMORY_POOL(CLASS) : public DL::Memory<CLASS,DL::NullLock,ACE_Cached_Allocator<CLASS,ACE_Null_Mutex> >
#else
#define MEMORY_POOL(CLASS) : public DL::Memory<CLASS,DL::NullLock,DL::QS::Allocator<CLASS> >
#endif
#else
#define MEMORY_POOL(CLASS)
#endif

class EngineMonitor MEMORY_POOL(EngineMonitor)
{

public:
	EngineMonitor()
	{
	}
	virtual ~EngineMonitor()
	{
	}

private:
	int __service;
	int __monitor;
};


Memroy重载了C++类的new跟delete,成员都是static的,这样,同一个最终类经模块化后,都共用一个allocator,这样就可以实现内存池了。在new的时候从allocator预先分配的内存中,拿出一块符合类的内存块大小,在不用的时候delete掉,把内存块放回到allocator中。不过Memroy每一次new后,都调用了最终类的构造函数,增加了时间开销。最后我用ACE_Cached_Allocator和DL::QS::Allocator<T>做了一次测试比较,感觉都差不多,嘿嘿,不错。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是封装nodejs使用mysql2的连接池的写法: ```javascript const mysql = require('mysql2/promise'); class MysqlPool { constructor(config) { this.pool = mysql.createPool(config); } async execute(sql, values) { const connection = await this.pool.getConnection(); try { const [rows] = await connection.execute(sql, values); return rows; } catch (err) { throw err; } finally { connection.release(); } } async beginTransaction() { const connection = await this.pool.getConnection(); try { await connection.beginTransaction(); return connection; } catch (err) { connection.release(); throw err; } } async commitTransaction(connection) { try { await connection.commit(); connection.release(); } catch (err) { await connection.rollback(); connection.release(); throw err; } } async rollbackTransaction(connection) { try { await connection.rollback(); connection.release(); } catch (err) { connection.release(); throw err; } } } module.exports = MysqlPool; ``` 在上面的代码中,我们使用了 `mysql2/promise` 模块创建了一个连接池,然后封装了一些常用的方法,包括 `execute`、 `beginTransaction`、 `commitTransaction` 和 `rollbackTransaction`。其中,`execute` 方法用于执行 SQL 语句,`beginTransaction` 方法用于开启事务,`commitTransaction` 方法用于提交事务,`rollbackTransaction` 方法用于回滚事务。 使用时,只需要实例化 `MysqlPool` 类,然后调用相应的方法即可。例如: ```javascript const MysqlPool = require('./mysql-pool'); const config = { host: 'localhost', user: 'root', password: '123456', database: 'test', waitForConnections: true, connectionLimit: 10, queueLimit: 0, }; const pool = new MysqlPool(config); async function getUsers() { const sql = 'SELECT * FROM users'; const result = await pool.execute(sql); return result; } getUsers().then((result) => { console.log(result); }).catch((err) => { console.error(err); }); ``` 上面的代码中,我们首先创建了一个 `config` 对象,包含了数据库连接的配置信息。然后实例化了一个 `MysqlPool` 对象,并且调用了 `execute` 方法执行了一条 SQL 查询语句。最后输出查询结果或者错误信息。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值