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

隨筆-19  評論-2  文章-0  trackbacks-0

========================
Effective C++   資源管理類(resource-managing classes)
書作者:Scott Meyers
原筆記作者:Justin
========================

Item 13 :以對象管理資源
---------------------------------------
 tag:auto_ptr   shared_ptr   RAII    RSCP   智能指針
 
 要利用對象來管理資源(可以是分配出來的內存、互斥量等)。這樣可以避免因為寫代碼時的疏忽而導致的資源流失(可以是內存的泄漏,也可能是忘了解鎖)。

 將釋放資源的代碼放在對象的析構函數中,只要對象被析構,就可以保證資源被完整釋放。
 C++的析構函數自動調用機制(C++’s automatic destructor invocation)能夠保證當對象脫離控制時該對象的析構函數被調用(比如一個對象在某函數內部定義,那么在函數執行結束后,這個對象的析構函數會被自動調用以銷毀此對象)。
 是個好辦法,至少對我這樣時常丟三落四的人來說是個福音。何況這樣的對象大多數情況下不用自己寫,auto_ptr(智能指針, smart pointer的一種)就可以勝任。

  std::auto_ptr<void *>  pMem(AllocAndInitMemory());
 
 高亮的部分即說明了auto_ptr的用法,也附帶示范了所謂的RAII(Resource Acquisition Is Initialization)資源取得時機便是初始化時期。
 
 這里的auto_ptr就像是個陪女友逛街的可憐家伙,女朋友(用戶)說要什么,auto_ptr就乖乖的去買來(申請),想要用的時候就趕緊拿出來給女友用,哪怕她忘了曾經買了某件衣服,auto_ptr還是會老老實實地送回家里,不用擔心會弄丟或是搞臟。嗯,有點做上帝的感覺吧?

 不過,沒有什么是十全十美的。大師馬上就說到了用對象管理資源的問題,好吧,應該說是需要注意的地方:
 首先不能用一個以上的對象,比如說auto_ptr,管理同一個資源。這個很好理解,就像一個漂亮的女孩子腳踏多條船(同時定義了多個auto_ptr),但是她必須要小心,不能讓多個對象參加同一個約會:今天逛街的時候喊上了小張就不能叫小王,明天一起吃飯如果約了小李就別再和小趙定時間:一個資源一次只能讓一個對象來管理。
 這樣的規則用在auto_ptr上就是書中奇怪的“=”行為:兩個auto_ptr對象A和B,A=B運算的結果是A接管了B管理的資源,B指向的是null。(如果記不起來了,具體代碼見書)這樣的行為很像是傳遞:小李陪女朋友逛完街后,送她到人民廣場,在那里小陳約好了和她一起看電影。到了人民廣場之后小陳摟著女人開心的走了,只剩下小李一個孤單的背影,杯具啊杯具……

 為了避開這種尷尬且極易被誤解的“=”操作,出現了以shared_ptr為代表的reference-counting smart pointer(RCSP)(引用計數型智能指針?)。它們可以“共事一夫”,由一個公用的reference counter來計數,某個shared_ptr在準備拋棄一個資源時先參考reference counter的值,如果非零,說明還有其他的“姐妹”在罩著資源,不需要也不可以釋放該資源;如果值為零,說明當前只有她一個人了,于是真正的擔當起smart pointer的責任:釋放資源。
 
  std::shared_ptr<void *>  pMem(AllocAndInitMemory());

 重點不在于是用auto_ptr還是shared_ptr還是其他的什么東東,而是要領會精神——使用對象來管理資源。比如說用string對象來管理一個字符串而不是手工申請一片內存然后用個指針“吧唧”粘上去就開始用了。
 不能再動態分配而得的 array 上使用 auto_ptr 或 tr1::shared_ptr,因為兩者在析構的時候調用的是delete而不是delete[].
 要擁有針對數組而設計的,可用 boost::scoped_array 和 boost::shared_array classes.
 


Item 14: 在管理類中小心 coping 行為
--------------------------------------------
 tag: RAII  
 
 RAII守則:資源在構造期間獲得,在析構期間釋放。
 
 RAII對象被復制:
  ·不允許拷貝。當資源本身不能復制時,對象可以說“不”。怎么做?回到Item6……
  ·使用Reference-Count(引用計數),可以用上節說到的shared_ptr來干這個事,這里順帶介紹了shared_ptr提供的一個接口:一個可以在構造對象時定義的delete操作:如果對象是內存就是釋放,如果對象是鎖就是解鎖。
  ·直接復制。別人有什么,你就直接原封不動也復制一份。如果是內存的話說得過去,如果是鎖,我想還是不能這樣亂用哈。
  ·移交所有權。這個不算是真正意義的復制,移交手續而已。最典型的例子就是auto_ptr的復制行為。



Item 15: 在資源管理類中提供對原始資源的訪問
-------------------------------------------------
 tag:返回原始資源
 
 ·在使用對象管理資源的同時也要留出接口給那些需要繞過對象而直接訪問資源的人。
    
 寫個函數暴露出指向資源的指針就可以。書里講得更多的是用怎樣的函數:
 
 顯式轉換(explicit conversion)
 可以實現一個get函數,或是*、->運算,返回指向資源的指針。
 
 隱式的轉換函數(implicit conversion),
 
 但是個人覺得實際工作中應該是不提倡這樣做的,因為隱式的轉換極有可能發生在編程者沒有意識的情況下,導致后面的代碼出錯。

 class Font {
 public:
 //  ..
 // implicit conversion function
   operator FontHandle() const { return f; }
 //  ..
 };
 上面代碼的應用如下,f本身為Font類型,(changeFontSize第一個參數為FontHandle),但是由于隱式轉換,類型變成了FontHandle。

 Font f(getFont());
 int newFontSize;
 //..
 // implicitly convert Font to FontHandle
 changeFontSize(f, newFontSize);
 
 為了能兼容更多的API,需要留出接口提供對資源的直接訪問。
 隱式或顯示主要取決于RAII class 被設計執行的特定工作,以及它被使用的狀況。
 
 
Item 16 : 成對使用new和 delete時采用相同形式
---------------------------------------------------
 tag:  new delete

 ·用new分配一個內存對象時,語法格式是new a;用delete釋放一個內存對象時,語法格式是delete a;
 ·用new分配一組內存對象時,語法格式是new a [num_of_elem]; 用delete釋放一組內存對象時,語法格式是delete [] a;
 
 new或是delete包含了兩個階段:

 new:申請并分配內存空間;調用構造函數構造即將使用空間的對象
 delete:調用析構函數析構使用空間的對象;釋放內存
 
 分配內存給一組對象的時候,編譯器一般會在這一片內存前端(或是其他什么地方)插入一小段信息,用來標明這片內存是給多少個對象的,然后反復調用構造函數來創建這一組對象。當用delete []的時候,釋放內存的操作就會以該信息為依據,反復調用對象的析構函數對這組對象進行釋放。(下面的[n]就是這段信息)
 [n][MEM]
 而如果只是分配內存給一個對象,這段信息就不存在了。直接在這片內存上應用析構函數。
 
 于是用delete []去釋放new的內存,或是用delete去釋放new []的內存,都會造成不可預計的后果。



Item 17 : 將new語句單獨寫
----------------------------------
 tag:   newed
 
 processWidget(std::tr1::shared_ptr<Widget>(new Widget), priority());這行語句有問題,這個復雜的參數表包含了三個動作:

  ·new 一個 Widget
  ·用new的Widget做為參數執行share_ptr的構造函數
  ·執行priority
 C++的某個編譯器可能為了效率而自作主張,導致這三個動作的執行順序是不確定的!因此上面的動作執行順序可能是這樣的:

  ·new 一個 Widget
  ·執行priority
  ·用new的Widget做為參數執行share_ptr的構造函數 

 這個時候如果priority的執行出錯而引發異常,就會發生內存泄漏(Memory Leak),因為new出來的Widget再也無法跟蹤了。

 而解決方法也很簡單,不要妄圖一行寫完所有程序,分開來老老實實寫就是了:

    std::tr1::shared_ptr<Widget> pw(new Widget);
    processWidget(pw, priority());  

 VC++下不會。

 

 

 

posted on 2010-03-15 22:48 Euan 閱讀(535) 評論(0)  編輯 收藏 引用 所屬分類: C/C++
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            久久久精品国产99久久精品芒果| 日韩午夜高潮| 久久亚洲免费| 玖玖玖免费嫩草在线影院一区| 在线欧美日韩| 亚洲精品日韩久久| 国产精品日韩一区二区三区| 久久精品30| 欧美h视频在线| 亚洲一区二区三区精品动漫| 小处雏高清一区二区三区 | 欧美一级淫片播放口| 国内精品国语自产拍在线观看| 欧美成人精品在线观看| 欧美国产激情二区三区| 香港久久久电影| 久久亚洲高清| 亚洲欧美日韩国产精品| 久久久人成影片一区二区三区| 亚洲乱亚洲高清| 亚洲在线观看视频| 亚洲国产精品电影| 在线亚洲电影| 91久久精品国产91性色tv| 亚洲一区二区三| 亚洲麻豆av| 久久精品国产亚洲aⅴ| 中国女人久久久| 久久一区国产| 国产女同一区二区| 国产精品久久久久久久午夜| 男男成人高潮片免费网站| 欧美日韩在线播放一区二区| 久久免费一区| 国产精品捆绑调教| 亚洲啪啪91| 激情欧美一区二区| 亚洲一区二区三区色| 亚洲美洲欧洲综合国产一区| 久久精品国产综合精品| 久久av老司机精品网站导航| 欧美视频不卡中文| 亚洲国产精品一区二区www在线| 国产欧美日韩精品丝袜高跟鞋| 亚洲区欧美区| 亚洲精品婷婷| 免费国产自线拍一欧美视频| 久久久久久久一区| 国产精品亚洲欧美| 亚洲视频中文| 亚洲在线国产日韩欧美| 欧美日本乱大交xxxxx| 亚洲国产二区| 亚洲精品乱码久久久久久黑人 | 亚洲欧洲在线看| 亚洲国产老妈| 老鸭窝毛片一区二区三区| 久久福利影视| 国产视频一区二区三区在线观看| 一片黄亚洲嫩模| 一区二区三区四区精品| 欧美母乳在线| 日韩亚洲视频在线| 中国女人久久久| 国产精品成人国产乱一区| 一区二区三区视频在线看| 午夜精品久久一牛影视| 国产精品大全| 亚洲欧美一区二区三区极速播放 | 午夜精品在线看| 国产精自产拍久久久久久| 亚洲砖区区免费| 久久久久久电影| 在线观看欧美亚洲| 麻豆精品视频在线观看视频| 亚洲高清视频在线| 亚洲一区二区三| 国产区精品在线观看| 久久国产一二区| 欧美激情一区二区三级高清视频 | 永久555www成人免费| 久久人人97超碰精品888| 亚洲国产小视频在线观看| 洋洋av久久久久久久一区| 欧美性天天影院| 欧美影院成人| 亚洲国产美女久久久久| 亚洲一区欧美二区| 国产一区二区精品| 欧美成人一区二区三区| 一本色道久久综合| 久久久亚洲人| 欧美日韩一区高清| 亚洲高清不卡在线| 中日韩美女免费视频网址在线观看| 欧美三级网址| 久久人人看视频| 亚洲精品你懂的| 亚洲女女做受ⅹxx高潮| 一区二区在线观看视频| 欧美日韩国产专区| 久久精品一区二区三区不卡| 亚洲日本一区二区| 久久久久欧美精品| 99精品久久| 国产欧美一区二区三区另类精品 | 欧美韩日高清| 午夜精品视频在线观看| 亚洲欧洲综合另类| 久久久久国产精品www| 国产精品99久久久久久人| 狠狠色丁香婷婷综合影院| 欧美日韩三级一区二区| 久久免费偷拍视频| 亚洲欧美一区二区原创| 99在线精品视频在线观看| 免费观看成人鲁鲁鲁鲁鲁视频| 亚洲欧美日韩精品久久奇米色影视 | 午夜精品影院在线观看| 亚洲精一区二区三区| 男女av一区三区二区色多| 久久大香伊蕉在人线观看热2| 夜夜爽av福利精品导航| 亚洲精品国产精品久久清纯直播| 国产日韩欧美精品| 国产精品日韩在线一区| 欧美日韩一区二区三区在线看| 美女露胸一区二区三区| 久久精品30| 久久国产精品久久国产精品| 亚洲婷婷在线| 亚洲一区二区在线| 亚洲网在线观看| 亚洲视频观看| 亚洲天堂网在线观看| 亚洲免费av电影| 亚洲免费观看| 一本久久a久久精品亚洲| 亚洲欧洲在线免费| 亚洲高清在线观看一区| 欧美激情二区三区| 欧美激情第六页| 亚洲精品1区2区| 亚洲精品字幕| av不卡免费看| 亚洲欧美成人综合| 久久aⅴ国产紧身牛仔裤| 久久久精品一区| 老司机免费视频一区二区| 蜜桃av一区二区| 欧美精品综合| 国产精品超碰97尤物18| 国产欧美日韩激情| 亚洲成人直播| 亚洲精品专区| 亚洲午夜激情| 欧美在线免费视屏| 欧美成人午夜77777| 亚洲国产婷婷香蕉久久久久久99| 日韩视频在线免费| 欧美亚洲在线| 免费在线观看精品| 欧美午夜美女看片| 黄色成人av网站| 一区二区三区精密机械公司| 亚洲欧美日韩中文在线制服| 亚洲欧美视频在线观看| 亚洲欧美日韩在线高清直播| 欧美亚洲综合在线| 久久亚洲精选| 欧美图区在线视频| 亚洲电影下载| 亚洲综合色在线| 男人插女人欧美| 一区二区电影免费观看| 久久久久亚洲综合| 欧美日韩在线一区| 国内欧美视频一区二区| 日韩网站免费观看| 久久久久久97三级| 99视频国产精品免费观看| 久久精品国产精品亚洲| 欧美日韩激情小视频| 国产一区av在线| 亚洲午夜激情在线| 欧美成人网在线| 欧美在线www| 国产精品v欧美精品v日韩精品 | 欧美风情在线观看| 国产一区在线观看视频| 亚洲一区二区三区午夜| 久久夜色精品国产欧美乱极品| 99热精品在线观看| 欧美高清在线精品一区| 黄网动漫久久久| 午夜精品一区二区三区电影天堂| 亚洲国产成人av在线| 久久国产精品一区二区三区| 国产精品久久一卡二卡| 一区二区激情视频|