青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

洛譯小筑

別來無恙,我的老友…
隨筆 - 45, 文章 - 0, 評論 - 172, 引用 - 0
數據加載中……

[ECPP讀書筆記 條目14] 要注意資源管理類中的復制行為

條目13中介紹了“資源獲取即初始化”(Resource Acquisition Is Initialization,簡稱RAII)的概念,它是資源管理的中心內容。同時條目13中還使用auto_ptrtr1::shared_ptr作為示例,描述了如何利用這一概念來管理堆上的資源。然而并不是所有的資源都分配于堆上,對于不分配于堆上的資源,諸如auto_ptrtr1::shared_ptr這一類的智能指針并不適合于處理它們。這是千真萬確的,你必須不時地自己動手,創建自己的資源管理類。

舉例說,你正使用一個C版本的API所提供的lockunlock函數來處理Mutex類型的互斥對象:

void lock(Mutex *pm);              // 通過pm為互斥量上鎖

void unlock(Mutex *pm);            // 為互斥量解鎖

為了確保你曾上鎖的互斥量都得到解鎖,你應該自己編寫一個類來管理互斥鎖。這樣的類的基本結構應遵循RAII的原理,那就是:資源在構造過程中獲得,在析構過程中釋放:

class Lock {

public:

  explicit Lock(Mutex *pm)

  : mutexPtr(pm)

  { lock(mutexPtr); }                   // 獲取資源

 

  ~Lock() { unlock(mutexPtr); }         // 釋放資源

 

private:

  Mutex *mutexPtr;

};

客戶通過傳統的RAII風格來使用Lock類:

Mutex m;                           // 定義互斥量以便使用

...

{                                  // 創建程序塊用來定義臨界區

 Lock ml(&m);                      // 為互斥量上鎖

...                                // 進行臨界區操作

}                                  // 在程序塊末尾互斥量將自動解鎖

這樣可以正常工作,但是如果復制一個Lock對象,將會發生些什么呢?

Lock ml1(&m);                      // m上鎖

 

Lock ml2(ml1);                     // ml1復制給ml2

                                   // 將會發生什么呢?

有一個問題是所有的RAII類創建者必須面對的,那就是:當復制一個RAII對象時應做些什么。以上是對于這個一般化問題的一個較具體的示例。大多數時候,以下四種可行的方案供你選擇。

禁止復制。在許多情況下,允許RAII被復制沒有任何意義。比如對于Lock類來說就是這樣,因為復制同步原型在大多數情況下都沒有什么意義。當復制一個RAII類無意義時,你就應該禁止它。條目6中詳細介紹了實現方法:將拷貝賦值運算符聲明為私有的。對于Lock而言,應該是下面的情形:

class Lock: private Uncopyable {      // 防止復制 參見條目6

public:

 ...                                   // 同上

};

為潛在生成的資源進行引用計數。有時,我們期望能保留對一個資源的所有權,直到其所涉及的最后一個對象被刪除為止。在這種情況下,復制一個RAII對象將會添加一個引用資源對象的計數。這就是tr1::shared_ptr所使用的“復制”的含義。

通常情況下,RAII類可以通過包含一個tr1::shared_ptr數據成員來實現引用計數復制行為。舉例說,如果Lock在設計時之初就期望使用引用計數,它可能會用tr1::shared_ptr<Mutex>代替Mutex*來作為mutexPtr的類型。但是不幸的是,tr1::shared_ptr默認的行為是:當引用計數值變為零時,刪除其所指向的內容,但這不是我們想要的。當一個Mutex用完時,我們希望對其進行的操作是解鎖,而不是刪除它。

所幸的是,tr1::shared_ptr允許指定一個“刪除器”,它是一個函數或一個函數對象,用于在引用計數值為零時進行調用。(auto_ptr并不包含這一特性,它總是刪除它所指向的內容。)刪除器是tr1::shared_ptr構造函數的第二個(可選的)參數,所以代碼應該是這樣的:

class Lock {

public:

  explicit Lock(Mutex *pm)     // 初始化shared_ptr,參數為

  : mutexPtr(pm, unlock)       // 指向Mutex的指針和解鎖函數

 

    lock(mutexPtr.get());      // 關于"get"的信息請參見條目15

  }

 

private:

  std::tr1::shared_ptr<Mutex> mutexPtr;

};                             // 使用shared_ptr而不是原始指針

在本示例中,請注意Lock類不再聲明析構函數。這是因為我們不再需要它了。條目5中介紹了類的析構函數(無論是編譯器自動生成的還是用戶自定義的)會自動為類的非靜態數據成員進行析構。就像本示例中的mutexPtr。然而,當互斥量的引用計數變為零時,mutexPtr將會自動調用tr1::shared_ptr的刪除器unlock。(此時如果你為代碼添加了一段注釋,告訴人們你并沒有忘記編寫析構函數,你只是借助了默認的編譯器行為。人們看了這樣的注釋思路會更清晰一些。他們會感激你的。)

復制潛在生成的資源。一些時候,你可以在需要的情況下為資源復制出任意份數的副本,此時你需要一個資源管理類的唯一理由就是:確保每份副本在其工作完成之后得到釋放。在這種情況下,復制資源管理對象的同時,也要復制出其所涉及的資源。也可以說,復制一個資源管理對象時,將進行“深度復制”。

標準string類型的一些實現版本中,包含著一個指向堆內存的指針,這個指針所指向的就是字符串所保存的位置。這樣的string對象包含著一個指向堆內存的指針。當一個string對象被復制時,將同時復制這一指針和其指向的內存。這樣的string就進行了一次深度復制。

傳遞潛在生成資源的所有權。在少數情況下,你可能需要確保僅僅有一個RAII對象引用了一個原始的資源,當復制這一RAII對象時,資源的所有權也將從源對象傳遞到目標對象。如同條目13中所解釋的,這是通過auto_ptr所實現的“復制”的含義。

拷貝函數(拷貝構造函數和拷貝賦值運算符)可以由編譯器自動生成,但是如果編譯器自動生成版本無法滿足你的需要(條目5中解釋了C++的默認行為),你就應該自己編寫這些函數。在一些情況下,你可能還會需要支持這些函數的一般化的版本。這些版本將在條目45中介紹。

時刻牢記

由于復制一個RAII對象必須要同時復制其所管理的資源,因此資源的復制行為決定RAII對象的復制行為。

RAII類有兩種一般性的復制行為:禁止復制和進行資源計數。同時其他的行為也是可能存在的。

posted on 2007-05-11 18:40 ★ROY★ 閱讀(967) 評論(1)  編輯 收藏 引用 所屬分類: Effective C++

評論

# re: 【翻譯】[Effective C++第三版?中文版][第14條]要留心資源管理類中的復制行為  回復  更多評論   

boost的scoped_ptr使用的第一個策略:禁止復制

:)
2007-05-23 10:15 | recorder
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            国产人妖伪娘一区91| 日韩一级在线| 欧美在线综合| 国产精品免费小视频| 中文欧美字幕免费| 999亚洲国产精| 欧美三级在线视频| 亚洲一区二区在线免费观看视频| 亚洲国产成人精品视频| 中日韩高清电影网| 欧美视频你懂的| 亚洲欧美欧美一区二区三区| 一区二区欧美日韩视频| 欧美网站在线观看| 午夜免费在线观看精品视频| 亚洲综合三区| 国内免费精品永久在线视频| 久久男女视频| 欧美sm重口味系列视频在线观看| 亚洲精品久久7777| 在线亚洲免费| 国内在线观看一区二区三区| 久久中文精品| 欧美国产视频在线观看| 亚洲欧美成人精品| 久久成人一区二区| 国产一区二区在线免费观看| 欧美国产免费| 欧美色图麻豆| 亚洲午夜极品| 久久精品国产在热久久| 亚洲国产清纯| 在线一区二区三区做爰视频网站| 国产精品视频| 久久久久久电影| 欧美黄在线观看| 欧美在线一二三区| 蜜桃av一区二区| 亚洲欧美精品suv| 巨乳诱惑日韩免费av| 亚洲午夜久久久| 久久精品亚洲一区二区三区浴池| 99国产精品99久久久久久粉嫩 | 欧美性大战久久久久久久| 黄色欧美日韩| 午夜日韩av| 亚洲精品国产视频| 亚洲欧美精品suv| 最新日韩精品| 午夜亚洲激情| 亚洲一本大道在线| 蜜臀av性久久久久蜜臀aⅴ| 亚洲欧美日本精品| 模特精品裸拍一区| 欧美在线精品一区| 久久精品色图| 欧美在线影院| 欧美日韩亚洲一区二区三区四区| 卡一卡二国产精品| 国产精品亚洲а∨天堂免在线| 欧美福利电影在线观看| 国产一区二区日韩| 亚洲一区二区网站| 亚洲欧洲视频在线| 久久精品网址| 久久精品国产v日韩v亚洲 | 蜜月aⅴ免费一区二区三区| 欧美视频一区二区三区| 欧美国产极速在线| 国产伦理精品不卡| 日韩视频国产视频| 在线视频一区观看| 欧美极品在线播放| 免费在线国产精品| 激情久久综合| 久久久久久久久久久久久女国产乱 | 欧美激情自拍| 亚洲第一区色| 理论片一区二区在线| 久久久青草婷婷精品综合日韩| 欧美日韩精品免费观看视一区二区| 欧美国产精品久久| 91久久香蕉国产日韩欧美9色 | 一区二区三区久久| 欧美大片专区| 亚洲欧洲日韩女同| 亚洲精品免费在线观看| 欧美国产精品中文字幕| 亚洲日本理论电影| 亚洲日本久久| 欧美国产亚洲精品久久久8v| 亚洲第一天堂av| 99视频精品在线| 欧美视频在线看| 亚洲一二三四久久| 欧美本精品男人aⅴ天堂| 一区二区高清视频| 国产一区二区看久久| 欧美激情在线有限公司| 亚洲综合色丁香婷婷六月图片| 欧美成人在线免费观看| 亚洲欧美中日韩| 亚洲国语精品自产拍在线观看| 欧美日韩在线精品| 亚洲女爱视频在线| 欧美黄污视频| 午夜在线电影亚洲一区| 亚洲国产专区校园欧美| 久久精品国产综合| 99v久久综合狠狠综合久久| 国产亚洲一区二区三区在线观看 | 亚洲国产精品福利| 久久久7777| 亚洲少妇中出一区| 亚洲激情图片小说视频| 国产亚洲二区| 欧美日韩直播| 欧美成黄导航| 久久久久久久久久久久久9999| 亚洲图片在线| 亚洲精品日韩精品| 欧美激情影音先锋| 久久亚洲私人国产精品va| 午夜影院日韩| 亚洲一区二区欧美日韩| 99国产精品久久久| 亚洲精品久久在线| 亚洲高清视频在线观看| 国内精品久久久久久影视8| 国产精品日韩高清| 欧美亚一区二区| 欧美日韩一区二区三区在线看 | 久久久精品国产免费观看同学| 亚洲永久在线| 亚洲欧美日韩精品久久奇米色影视 | 欧美α欧美αv大片| 久久综合狠狠综合久久综青草| 欧美一区二区久久久| 亚洲一区三区电影在线观看| 一区二区久久久久| 亚洲视频在线一区| 亚洲免费在线视频| 欧美一区二区福利在线| 久久精品官网| 久久最新视频| 欧美成人蜜桃| 亚洲人成网站影音先锋播放| 亚洲精品欧美| 中文精品一区二区三区| 亚洲在线视频观看| 欧美一区二区三区免费观看| 欧美在线免费视频| 久久久久国内| 欧美激情麻豆| 欧美色大人视频| 国产农村妇女毛片精品久久麻豆| 国产日韩欧美三级| 亚洲成人在线观看视频| 亚洲精品免费观看| 亚洲一区二区三区免费观看| 性视频1819p久久| 久久久免费精品视频| 亚洲高清三级视频| 亚洲深夜福利视频| 久久久久久亚洲精品中文字幕| 蜜桃久久av| 国产精品青草久久| 亚洲国产精品123| 洋洋av久久久久久久一区| 性欧美暴力猛交另类hd| 欧美大胆a视频| 亚洲视频导航| 久久免费国产| 国产精品高精视频免费| 红桃av永久久久| 亚洲午夜电影在线观看| 久久久噜噜噜| 一本色道久久88综合日韩精品| 亚洲免费av电影| 男人的天堂亚洲在线| 亚洲精品美女久久久久| 欧美一二三区精品| 欧美精品午夜| 伊甸园精品99久久久久久| 在线一区二区三区四区五区| 久久尤物电影视频在线观看| 日韩小视频在线观看| 久久在线视频在线| 国产精品日韩二区| 一区二区三区四区国产| 久久一区视频| 亚洲欧美偷拍卡通变态| 欧美好骚综合网| 黑人操亚洲美女惩罚| 亚洲男人的天堂在线| 亚洲电影免费观看高清| 久久av资源网| 国产女精品视频网站免费| 一本色道久久88综合亚洲精品ⅰ| 免费成人激情视频|