#pragma once
template<typename T,std::size_t nNum>
class CMemPool
{
public:
CMemPool(){ Init();}
~CMemPool() { Fini();}
T* GetElement();
void ReleaseElement(T* t1);
void Init();
void Fini();
protected:
std::list<T*> m_list;
};
template<typename T,std::size_t nNum>
void CMemPool<T,nNum>::Init()
{
for (size_t i=0; i<nNum; i++)
{
T* t1 = new T;
if (t1 != NULL)
{
m_list.push_back(t1);
}
}
}
template<typename T,std::size_t nNum>
void CMemPool<T,nNum>::Fini()
{
std::list<T*>::iterator it = m_list.begin();
for (; it != m_list.end();)
{
T* tTmp = *it;
it = m_list.erase(it);
if (tTmp != NULL)
delete tTmp;
}
}
template<typename T,std::size_t nNum>
T* CMemPool<T,nNum>::GetElement()
{
if (m_list.size() == 0)
Init();
std::list<T*>::iterator it = m_list.begin();
T* t1 = NULL;
for(; it != m_list.end();)
{
if (*it == NULL)
{
it = m_list.erase(it);
}
else
{
t1 = *it;
m_list.erase(it);
break;
}
}
return t1;
}
template<typename T,std::size_t nNum>
void CMemPool<T,nNum>::ReleaseElement(T* t1)
{
if (t1 != NULL)
m_list.push_back(t1);
}
本文介绍了一个通用的内存池类CMemPool的实现方法,该类能够为特定类型的对象提供高效分配和释放机制。通过预先创建并管理一组对象实例,CMemPool能够在运行时快速响应对象获取请求,并在不再需要时回收这些对象。
868

被折叠的 条评论
为什么被折叠?



