亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

More Effective C++之引用計數

2019-11-17 05:28:06
字體:
來源:轉載
供稿:網友

  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;
};
  這是Meyers給出的String的實現,然而我的觀點是假如沒有非凡的必要的話,對stirng最好不要使用引用計數,因為在多線程程序中同步的代價要大于引用計數本身的好處,得不償失。

  假如StringValue是一個現成的類,無法修改它的實現,那怎么辦?沒關系可以用委托,下面是一個典型的實現:


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 RCiptr
{
 public:
  RCIPtr(T* realPtr = 0):counter(new CountHolder)
  {
   counter->pointee = realPtr;
   init();
  }
  RCIPtr(constRCIPtr& rhs):counter(rhs.counter)
  {
   init();
  }
  ~RCIPtr()
  {
   counter->RemoveReference();
  }
  RCIPtr& operator = (constRCIPtr& rhs)
  {
   if (counter != rhs.counter)
   {
    counter->RemoveReference();
    counter = rhs.counter;
    init();
   }
   return *this;
  }
  constT* operator->()const
  {
   returncounter->pointee;
  }
  T* operator->()
  {
   makeCopy();
   returncounter->pointee;
  }
  constT& operator*() const
  {
   return *(counter->pointee);
  }
  T& operator*()
  {
   makeCopy();
   return *(counter->pointee);
  }
 private:
  struct CountHolder:publicRCObject
  {
   ~Count Holder(){deletepointee;}
   T* pointee;
  };
  Count Holder* counter;
  void init()
  { 
   if (counter->isShareable() == false)
   {
    T* oldValue = counter->pointee;
    counter = newCountHolder;
    counter->pointee = newT(*oldValue);
   }
   counter->AddReference();
  }
  void makeCopy()
  {
   if (counter->isShared())
   {
    T* oldValue = counter->pointee;
    counter->RemoveReference();
    counter = newCountHolder;
    counter->pointee = newT(*oldValue);
    counter->AddReference();
   }
  }
 };
 class Widget
 {
  public:
   Widget(intSize){}
   Widget(constWidget& rhs){}
   ~Widget(){}
   Widget operator=(const Widget& rhs){}
   void doThis(){printf("doThis()/n");return;}
   int showThat() const{printf("showThat()/n"); return 0;}
  protected:
  private:
   inti;
 };

 class RCWidget
 {
  public:
   RCWidget(intsize):value(newWidget(size)){}
   void doThis(){value->doThis();}
   int showThat()const {returnvalue->showThat();}
  protected:
  private:
   RCIPtr<Widget> value;
};
  評估

  實現引用計數是需要有前提的,不是所有的情況下,使用引用計數都是合適的。適合情況如下:

  相對多的對象共享相對少量的實值。

  對象的實值產生或者銷毀的成本很高,或者占用很多內存。

  但是要記住,即使是Java也會有內存泄漏,不要指望小小的引用計數(上面簡單的實現)不會產生同樣的問題。

  引用計數是一項很深奧的技術,想想Java,所以需要很謹慎的對待,但愿它能帶來程序設計上的優化。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美午夜片欧美片在线观看| 欧美又大粗又爽又黄大片视频| 精品国产电影一区| 亚洲欧美三级在线| 久久精品99久久香蕉国产色戒| 久久精品国产一区二区三区| 亚洲国产天堂网精品网站| 热99在线视频| 国产999精品| 亚洲成人久久网| 欧美香蕉大胸在线视频观看| 日韩电影中文字幕| 久久伊人精品视频| 日韩欧美国产高清91| 亚洲国产又黄又爽女人高潮的| 国产精品精品久久久| 亚洲精品电影在线观看| 成人久久久久久久| 成人网在线免费看| 国产成人精品av在线| 色偷偷88888欧美精品久久久| 国产欧美在线视频| 国产精品一区二区久久国产| 欧美日韩在线视频一区二区| 国产日韩精品一区二区| 亚洲性生活视频在线观看| 亚洲精品国产欧美| 中文字幕少妇一区二区三区| 久久综合免费视频| 77777亚洲午夜久久多人| 亚洲毛片在线免费观看| 国模精品视频一区二区| 国内揄拍国内精品少妇国语| 欧美日韩国产一区在线| 日韩电视剧免费观看网站| 亚洲欧美日韩成人| www.欧美精品| 2019中文字幕免费视频| 精品夜色国产国偷在线| 国产视频自拍一区| 一区三区二区视频| 大胆欧美人体视频| 日韩欧美在线第一页| 欧美午夜宅男影院在线观看| 日韩成人在线播放| 国外视频精品毛片| 97超碰蝌蚪网人人做人人爽| 色综合男人天堂| 成人欧美一区二区三区在线湿哒哒| 亚洲欧美日本精品| 亚洲自拍欧美另类| 亚洲精品久久久久| 中文字幕亚洲在线| 欧美国产精品人人做人人爱| 亚洲成色777777女色窝| 国产精品三级久久久久久电影| 日韩av综合中文字幕| 久久久久久久亚洲精品| 91丨九色丨国产在线| 日韩电影免费观看在线| 精品国偷自产在线视频| 国产精品自拍偷拍| 不卡伊人av在线播放| 亚洲人成在线电影| 在线视频国产日韩| 国内精品免费午夜毛片| 亚洲精品资源在线| 性色av一区二区三区红粉影视| 97国产精品视频人人做人人爱| 亚洲高清免费观看高清完整版| 久久久久久久久久久亚洲| 国产乱肥老妇国产一区二| 91精品国产综合久久香蕉922| 国内精品久久久久影院 日本资源| 97免费在线视频| 国模吧一区二区三区| 96精品久久久久中文字幕| 精品女同一区二区三区在线播放| 日本免费一区二区三区视频观看| 日韩中文字幕亚洲| 亚洲精品电影网站| 亚洲大胆人体视频| 亚洲欧美国产一区二区三区| 91chinesevideo永久地址| 成人亚洲激情网| 亚洲精品美女久久久| 亚洲第一页中文字幕| 国产精品精品久久久| 欧美亚洲激情视频| 一区二区三区视频免费在线观看| 国产精品网站入口| 欧美精品videossex性护士| 国产在线不卡精品| 91av视频在线| 国产精品爽爽爽爽爽爽在线观看| 亚洲国产私拍精品国模在线观看| 亚洲va电影大全| 国产精品91久久| 久久精品一本久久99精品| 最近2019年日本中文免费字幕| 日韩成人av在线| 日韩视频欧美视频| 日韩欧美成人精品| 亚洲成人网久久久| 亚洲午夜女主播在线直播| 这里只有精品久久| 欧美日韩亚洲系列| 91美女片黄在线观看游戏| 午夜精品三级视频福利| 久久久久久亚洲精品不卡| 亚洲乱码av中文一区二区| 一区国产精品视频| 亚洲黄色www| 日本精品久久中文字幕佐佐木| 国产欧美精品xxxx另类| 亚洲精品一二区| 亚洲精品国产欧美| 国产精品欧美一区二区三区奶水| 国产精品女人久久久久久| 精品夜色国产国偷在线| 久久99久久亚洲国产| 国产日韩中文字幕| 精品美女国产在线| 成人黄色片网站| 亚洲加勒比久久88色综合| 亚洲欧美在线看| 亚洲天堂网在线观看| 欧美国产日韩一区二区| 精品久久香蕉国产线看观看亚洲| 色综合91久久精品中文字幕| 欧美精品videos| 欧美做爰性生交视频| 日本久久亚洲电影| 久久久久久久久爱| 欧美精品久久久久久久久久| 亚洲精品www久久久| 欧美成人免费视频| 日韩中文字幕免费视频| 1769国产精品| 成人h片在线播放免费网站| 色偷偷噜噜噜亚洲男人的天堂| 国模视频一区二区三区| 国产精品久久久久久av下载红粉| 夜夜嗨av色一区二区不卡| 欧美一级片免费在线| 亚洲三级av在线| 亚洲电影免费观看高清完整版在线观看| 欧美在线一区二区三区四| 亚洲一区二区福利| 一区国产精品视频| 国产精品综合久久久| 日日噜噜噜夜夜爽亚洲精品| 欧美理论片在线观看| 亚洲tv在线观看| 日韩欧美在线视频日韩欧美在线视频| 97国产一区二区精品久久呦| 91精品久久久久久久久久| 久久久久久久激情视频| 国产精品久久久久77777| 欧美体内谢she精2性欧美| 国产在线精品播放| 国产精品美女主播| 久久影院中文字幕| 日韩高清人体午夜|