ACE学习手记--- 智能指针(ACE_Auto_Ptr / ACE_Refcounted_Auto_Ptr)

 ACE库提供的智能指针的功能是相当强大的。主要有

ACE_Auto_Ptr

ACE_Refcounted_Auto_Ptr

ACE_Intrusive_Auto_Ptr

三个智能指针,其中用的比较多的却容易使用的是前面2个。最后一个需要在自己的类中实现一些规定的函数。在这里主要介绍前面2个指针的使用。

 

ACE_Auto_Ptr <X>

 

ACE_Auto_Ptr 更像RAII的应用一样。资源初始化即获取及其释放的C++惯用手法。也即ACE_Auto_Ptr 会拥有一个指向X对象的指针,并且在ACE_Auto_Ptr 退出作用于(生命期结束)时会自动是否X指针的资源。

如果在用户的应用程序不想删除X对象的指针,那么必须在ACE_Auto_Ptr 生命期结束时必须自己手动release掉X对象的指针。

ACE_Auto_Ptr不是基于引用计数的。当把一个ACE_Auto_Ptr对象赋值给另外一个ACE_Auto_Ptr对象时X对象的指针的所有权会发生转移。也就是X对象的指针有且仅有一个ACE_Auto_Ptr可以拥有该指针。

 

 

ACE_Refcounted_Auto_Ptr 是一个基于引用技术的智能指针,多个ACE_Refcounted_Auto_Ptr对象可以指向同一个X对象的指针。该智能指针提供的功能和ACE_Auto_Ptr大体相当。不同之处在于何时删除 智能指针所管理的X对象的指针。

在所有执行同一个X对象指针的ACE_Refcounted_Auto_Ptr 对象生命期结束时,才删除X对象的指针。

  1. /**
  2.  * @class ACE_Auto_Basic_Ptr
  3.  *
  4.  * @brief Implements the draft C++ standard auto_ptr abstraction.
  5.  * This class allows one to work on non-object (basic) types
  6.  */
  7. template <typename X>
  8. class ACE_Auto_Basic_Ptr
  9. {
  10. public:
  11.   typedef X element_type;
  12.   // = Initialization and termination methods
  13.   // = 初始化一个智能指针对象,该只能指针管理这个指针p指向的数据。
  14.   explicit ACE_Auto_Basic_Ptr (X * p = 0) : p_ (p) {}
  15.     // 把智能指针ap所管理的指针数据移交给新的智能指针对象。ap不再拥有对原始指针的管理权限。
  16.   ACE_Auto_Basic_Ptr (ACE_Auto_Basic_Ptr<X> & ap);
  17.   // 把 rhs所管理的原始指针的管理权限移交给本对象。如果本对象已经有管理的原始指针数据会先delete之前的指针
  18.   ACE_Auto_Basic_Ptr<X> operator= (ACE_Auto_Basic_Ptr<X> & rhs);
  19.   // 释放智能指针对象所管理的原始指针、调用底层的delete/free函数删除指针数据
  20.   ~ACE_Auto_Basic_Ptr (void);
  21.   // = Accessor methods.
  22.   // 得到原始指针的数据的引用
  23.   X operator *() const;
  24.   // 得到原始指针,不可删除该指针、但是可以修改指针所执行的数据。
  25.   X *get (voidconst;
  26.   // 得到原始指针、智能指针对象不再拥有对该指针的管理权限。与get不相同
  27.   // 需要用户自己管理X*指针变量的生命期。
  28.   X *release (void);
  29.   
  30.   // 与 operator=一样。会删除掉原先拥有的指针数据
  31.   void reset (X * p = 0);
  32.   /// Dump the state of an object.
  33.   void dump (voidconst;
  34.   /// Declare the dynamic allocation hooks.
  35.   ACE_ALLOC_HOOK_DECLARE;
  36. protected:
  37.   X *p_;
  38. };
  39. ACE_END_VERSIONED_NAMESPACE_DECL
  40. #if !defined (ACE_LACKS_AUTO_PTR) && /
  41.      defined (ACE_HAS_STANDARD_CPP_LIBRARY) && /
  42.             (ACE_HAS_STANDARD_CPP_LIBRARY != 0)
  43. #include <memory>
  44. #if defined (ACE_USES_STD_NAMESPACE_FOR_STDCPP_LIB) && /
  45.             (ACE_USES_STD_NAMESPACE_FOR_STDCPP_LIB != 0)
  46. using std::auto_ptr;
  47. #endif /* ACE_USES_STD_NAMESPACE_FOR_STDCPP_LIB */
  48. #else /* ACE_HAS_STANDARD_CPP_LIBRARY */
  49. /**
  50.  * @class auto_ptr
  51.  *
  52.  * @brief Implements the draft C++ standard auto_ptr abstraction.
  53.  */
  54. template <typename X>
  55. class auto_ptr : public ACE_Auto_Basic_Ptr<X>
  56. {
  57. public:
  58.   typedef X element_type;
  59.   // = Initialization and termination methods
  60.   explicit auto_ptr (X * p = 0) : ACE_Auto_Basic_Ptr<X> (p) {}
  61.   auto_ptr (auto_ptr<X> & ap) : ACE_Auto_Basic_Ptr<X> (ap.release ()) {}
  62.   X *operator-> () const;
  63. };
  64. template <typename X>
  65. class ACE_Auto_Ptr : public ACE_Auto_Basic_Ptr <X>
  66. {
  67. public:
  68.   typedef X element_type;
  69.   // = Initialization and termination methods
  70.   explicit ACE_Auto_Ptr (X * p = 0) : ACE_Auto_Basic_Ptr<X> (p) {}
  71.   // 得到原始指针 不可删除、但是可以修改指针所指向的数据。
  72.   X *operator-> () const;
  73. };

 

你可能感兴趣的:(ACE学习手记--- 智能指针(ACE_Auto_Ptr / ACE_Refcounted_Auto_Ptr))