C++通过list和template实现简单的对象池
2012-02-19 00:37
316 查看
远链接:http://www.cnblogs.com/lynch_world/archive/2011/07/21/2113244.html
C++通过list和template实现简单的对象池
通过重载new和delete实现简单的对象池,此处只是一个示例代码,并没有对对象上限个数进行限制及回收等操作一个简单的实现【编辑环境:linux+vi,编译环境:g++】:
C++语言:
#include <list>
#include <iostream>
using namespace std;
template<class T>
class object_pool
{
list<void *> data_list;
public:
void* malloc_data()
{
if(!data_list.empty())
{
list<void *>::iterator it = data_list.begin();
void *p = *it;
data_list.pop_front();
return p;
}
else
{
void* p = malloc(sizeof(T));
return p;
}
}
void free_data(void* p)
{
data_list.push_back(p);
}
};
class A
{
public:
int value;
A(int a):value(a){cout<<"A("<<a<<")
called"<<endl;}
~A() {cout<<"~A("<<value<<")
called"<<endl;}
static object_pool<A> pool_;
void* operator new (size_t size)
{
return pool_.malloc_data();
}
void operator delete(void* p)
{
pool_.free_data(p);
}
};
object_pool<A> A::pool_;
void main()
{
A* a1=new A(1);
A* a2=new A(2);
delete a1;
delete a2;
}
运行结果:
相关文章推荐
- C++通过list和template实现简单的对象池
- C++通过list和template实现简单的对象池
- c++通过栈和递归函数实现简单四则运算以及括号的的计算器
- c++stl库list简单的实现
- 实现一个简单的c++ list容器(含sort排序 链表归并算法实现)
- C++实现简单的对象池
- C++ 简单实现MFC ListControl 点击列头排序
- 通过重载new和delete实现简单的对象池
- C++ 通过main()函数输入参数,实现简单的四则运算
- c++ template 实现一个简单的"栈"
- List的简单C++实现
- C++通过bind,lambda表达式等实现简单的异步函数调用模型
- 通过重载new和delete实现简单的对象池
- C++ 简单实现MFC ListControl 点击列头排序
- 通过重载new和delete实现简单的对象池
- C++STL库list容器简单实现
- C++如何通过ostringstream实现任意类型转string
- 通过JAVA反射实现简单的ORM,将查询结果封装为对象
- C++实现简单的日期类
- 通过链表实现的多项式乘法【C++】