程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> C語言 >> VC >> vc教程 >> More Effective C++之引用計數

More Effective C++之引用計數

編輯:vc教程

Reference counting讓我想起了Java,當如果想用C++來實現Java的能力的話,那Reference counting必不可少。Reference counting可以節省程序的運行成本,大量的構造、析構、分配、釋放和拷貝的代價被省略。

實現

classRCObject
{
  public:
   RCObject():refCount(0),shareable(true){}
   RCObject(constRCObject&):refCount(0),shareable(true){}
   RCObject& operator=(constRCObject& rhs){return *this;}
   virtual ~RCObject()=0;
   void AddReference(){++refCount;}
   void RemoveReference(){if (--refCount == 0) deletethis;}
   void markUnshareable(){shareable = false;}
   bool isShareable() const{returnshareable;}
   bool isShared() const {returnrefCount > 1;}
  private:
   int refCount;
   bool shareable;
};
RCObject::~RCObject(){}
template <classT>
class RCPtr
{
  public:
   RCPtr(T* realPtr = 0):pointee(realPtr){init();}
   RCPtr(constRCPtr& rhs):pointee(rhs.pointee){init();}
   ~RCPtr(){if (pointee) pointee->RemoveReference();}
   RCPtr& operator = (constRCPtr& rhs)
   {
    if (pointee!=rhs.pointee)
    {
     if (pointee)
      pointee->RemoveReference();
      pointee = rhs.pointee;
      init();
    }
    return *this;
   }
   T* operator->() const { returnpointee;}
   T& operator*() const{return *pointee;}
  private:
   T* pointee;
   void init()
   {
    if (pointee == 0)
     return;
    if (pointee->isShareable() == false)
     pointee = newT(*pointee);
    pointee->AddReference();
   }
};
class String
{
  public:
   String(const char* value = ""):value(newStringValue(value)){}
   const char& operator[](intnIndex) const
   {
    return value->data[nIndex];
   }
   char& operator[](intnIndex)
   {
    if (value->isShared())
     value = newStringValue(value->data);
     value->markUnshareable();
     returnvalue->data[nIndex];
   }
  protected:
  private:
   struct StringValue:publicRCObject
   {
    char* data;
    String Value(constchar* initValue)
    {
     init(initValue);
    }
    String Value(constStringValue& rhs)
    {
     init(rhs.data);
    }
    void init(constchar * initValue)
    {
     data = newchar[strlen(initValue) + 1];
     strcpy(data,initValue);
    }
    ~String Value()
    {
     delete [] data;
    }
   };
   RCPtr<StringValue> value;
};

  1. 上一頁:
  2. 下一頁:
欄目導航
Copyright © 程式師世界 All Rights Reserved