首页 > 代码库 > 非线程安全对象池
非线程安全对象池
今天的微博有人讨论到对象池,我想到之前项目的实现,应该用模板来实现啊,唉,还是被前人的想法给框定了,不过实现一个特别简单,花了几分钟写了个:
#include <queue> #include <cstdio> using namespace std; const int DefaultPoolSize = 1024; template <class T> class ObejctPool{ private: queue<T*> m_OriBlock; queue<T*> m_ObjectBlock; const int m_DefaultBlockSize; public: ~ObejctPool(){ while (!m_OriBlock.empty()){ T* pBlock = m_OriBlock.front(); delete []pBlock; m_OriBlock.pop(); } } ObejctPool(int blockSize = DefaultPoolSize):m_DefaultBlockSize(blockSize){ } T* GetObject(){ if (true == m_ObjectBlock.empty()){ T* pNewObject = new T[m_DefaultBlockSize]; m_OriBlock.push(pNewObject); for (int i = 0; i < m_DefaultBlockSize; ++i){ m_ObjectBlock.push(pNewObject+i); } } T* pGetObject = m_ObjectBlock.front(); m_ObjectBlock.pop(); return pGetObject; } void ReleaseObejct(T* pObject){ if (0 == pObject){ return; } m_ObjectBlock.push(pObject); } }; int main(){ ObejctPool<int> obj; int* p = obj.GetObject(); *p = 1; printf("get:%d\n", *p); obj.ReleaseObejct(p); }
等下再实现个线程安全的。
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。