shared_ptr

shared_ptr_第1张图片

shared_ptr模板类有一个__shared_count类型的成员_M_refcount来处理引用计数的问题。__shared_count也是一个模板类,它的内部有一个指向Sp_counted_base_impl类型的指针_M_pi。所有引用同一个对象的shared_ptr都共用一个_M_pi指针。

当一个shared_ptr拷贝复制时, _M_pi指针调用_M_add_ref_copy()函数将引用计数+1。 当shared_ptr析构时,_M_pi指针调用_M_release()函数将引用计数-1。 _M_release()函数中会判断引用计数是否为0. 如果引用计数为0, 则将shared_ptr引用的对象内存释放掉。

   __shared_count(const __shared_count& __r)
      : _M_pi(__r._M_pi) // nothrow
      {
    if (_M_pi != 0)
      _M_pi->_M_add_ref_copy();
      }


      ~__shared_count() // nothrow
      {
    if (_M_pi != 0)
      _M_pi->_M_release();
      }

   _M_pi = new _Sp_counted_base_impl<_Ptr, _Deleter, _Lp>(__p, __d);

      void _M_release() // nothrow
      {
          if (__gnu_cxx::__exchange_and_add_dispatch(&_M_use_count, -1) == 1)
          {
              _M_dispose();
              // There must be a memory barrier between dispose() and destroy()
              // to ensure that the effects of dispose() are observed in the
              // thread that runs destroy().
              // See http://gcc.gnu.org/ml/libstdc++/2005-11/msg00136.html
              if (_Mutex_base<_Lp>::_S_need_barriers)
              {
                  _GLIBCXX_READ_MEM_BARRIER;
                  _GLIBCXX_WRITE_MEM_BARRIER;
              }
              if (__gnu_cxx::__exchange_and_add_dispatch(&_M_weak_count,
                          -1) == 1)
                  _M_destroy();
          }
      }


你可能感兴趣的:(C/C++)