对象池的实现

为了提高new对象的速度,工程师们提出了对象池的解决方案。即一次性分配大量的空间,供开发者创建对象使用;当分配的大量空间不够时,再次分配大量的空间。

嗯,这种方式,在内存池中是没有问题的。但是,由于对象构造时需要执行构造函数,析构时需要执行析构函数,这时就需要一种特殊的方式来解决在已经分配了的空间上执行构造函数。

这,就是placement new。

示例:

char * p = new char [sizeof(Object)];

Object * pObject = new (p) Object();

对应的,在析构对象时,需要:

pObject->~Object();

delete [] p;


下面给出我实现的ObjectPool

  1. #ifndef __OBJECT_POOL_H__  
  2. #define __OBJECT_POOL_H__  
  3.   
  4. #include "memorypool.h"  
  5.   
  6. template<typename TO>  
  7. class CObjectPool  
  8. {  
  9. public:  
  10.     CObjectPool()  
  11.     {  
  12.     }  
  13.   
  14.     ~CObjectPool()  
  15.     {  
  16.     }  
  17.   
  18.     /** 
  19.     * @brief 
  20.     * 初始化对象分配器 
  21.     * @param dwGrowCount : 每次增长的分配数量 
  22.     * @return  创建成功返回true,失败返回false 
  23.     **/  
  24.     bool PPAPI Create(unsigned int dwGrowCount = 1)  
  25.     {  
  26.         unsigned int dwUnitSize = sizeof(TO);  
  27.         bool ret = false;  
  28.         ret = m_Pool.Create(dwUnitSize, dwGrowCount * dwUnitSize);  
  29.         return ret;  
  30.     }  
  31.   
  32.     /** 
  33.     * @brief 
  34.     * 构造一个新的对象 
  35.     * @return  void* 
  36.     **/  
  37.     TO* PPAPI New()  
  38.     {  
  39.         return new (Malloc()) TO;  
  40.     }  
  41.   
  42.     template<typename P1>  
  43.     TO* PPAPI New(P1 p1)  
  44.     {  
  45.         return new (Malloc()) TO(p1);  
  46.     }  
  47.   
  48.     template<typename P1, typename P2>  
  49.     TO* PPAPI New(P1 p1, P2 p2)  
  50.     {  
  51.         return new (Malloc()) TO(p1, p2);  
  52.     }  
  53.   
  54.     template<typename P1, typename P2, typename P3>  
  55.     TO* PPAPI New(P1 p1, P2 p2, P3 p3)  
  56.     {  
  57.         return new (Malloc()) TO(p1, p2, p3);  
  58.     }  
  59.   
  60.     template<typename P1, typename P2, typename P3, typename P4>  
  61.     TO* PPAPI New(P1 p1, P2 p2, P3 p3, P4 p4)  
  62.     {  
  63.         return new (Malloc()) TO(p1, p2, p3, p4);  
  64.     }  
  65.   
  66.     template<typename P1, typename P2, typename P3, typename P4, typename P5>  
  67.     TO* PPAPI New(P1 p1, P2 p2, P3 p3, P4 p4, P5 p5)  
  68.     {  
  69.         return new (Malloc()) TO(p1, p2, p3, p4, p5);  
  70.     }  
  71.   
  72.     /** 
  73.     * @brief 
  74.     * 释放一个对象 
  75.     * @param p : 指向对象的指针 
  76.     * @return  void 
  77.     **/  
  78.     void PPAPI Delete(TO* p)  
  79.     {  
  80.         p->~TO();  
  81.         Free(p);  
  82.     }  
  83.   
  84. private:  
  85.     void* Malloc()  
  86.     {  
  87.         return m_Pool.Malloc();  
  88.     }  
  89.   
  90.     void Free(void* p)  
  91.     {  
  92.         m_Pool.Free(p);  
  93.     }  
  94.   
  95. private:  
  96.     CFixMemoryPool m_Pool;  
  97. };  
  98.   
  99. #endif  

其中的memorypool.h请见http://blog.csdn.net/huyiyang2010/article/details/7262315

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值