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

隨筆-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>
            久久av红桃一区二区小说| av成人免费在线| 免费视频一区二区三区在线观看| 亚洲视频高清| 洋洋av久久久久久久一区| 艳妇臀荡乳欲伦亚洲一区| 一区二区免费在线视频| 亚洲一区二区三区乱码aⅴ| 亚洲自拍偷拍网址| 久久精品官网| 欧美久久久久久久久久| 欧美色欧美亚洲高清在线视频| 国产精品久久久久91| 国产欧美日韩亚洲| 精品动漫3d一区二区三区| 亚洲人成网站精品片在线观看| 在线综合+亚洲+欧美中文字幕| 欧美一级大片在线观看| 欧美成人精品一区二区| 一区二区日本视频| 久久久精品免费视频| 欧美日韩精品一区二区天天拍小说 | 在线观看欧美精品| 艳妇臀荡乳欲伦亚洲一区| 欧美永久精品| 亚洲黄色在线视频| 亚洲天堂av在线免费观看| 久久久国产一区二区| 欧美午夜不卡影院在线观看完整版免费 | 麻豆精品国产91久久久久久| 欧美日韩国产精品一区| 国产一区二区三区日韩欧美| 99在线热播精品免费| 麻豆成人综合网| 亚洲愉拍自拍另类高清精品| 欧美福利在线| 亚洲成人资源| 久久久久国产精品一区三寸| 亚洲日韩欧美一区二区在线| 亚洲国内自拍| 国产精品久久综合| 亚洲精品久久久久久久久久久久久| 亚洲一区在线播放| 亚洲高清网站| 久久久久看片| 狠狠入ady亚洲精品| 亚洲欧美电影在线观看| 亚洲福利视频一区| 久久久久欧美精品| 国内视频一区| 久久九九精品99国产精品| 亚洲视频在线视频| 欧美手机在线视频| 一区二区三区国产盗摄| 亚洲国产精品激情在线观看| 欧美在线观看网站| 国产日韩精品综合网站| 午夜亚洲性色视频| 亚洲欧美日韩直播| 国产欧美精品在线播放| 久久成人精品一区二区三区| 亚洲一区影院| 国产日产亚洲精品| 久久久久久久久久久久久女国产乱 | 欧美揉bbbbb揉bbbbb| 亚洲精品在线电影| 亚洲国产精品久久久久秋霞影院| 麻豆国产精品一区二区三区| 亚洲国产天堂久久国产91| 欧美aⅴ一区二区三区视频| 久久亚洲风情| 亚洲精品你懂的| 亚洲人成网在线播放| 欧美三级在线视频| 欧美一区二区三区免费观看| 欧美一级片一区| 国内外成人免费激情在线视频| 久久一区二区三区国产精品| 久久亚洲精品一区| 亚洲精品中文字幕有码专区| 亚洲破处大片| 国产毛片一区| 免费观看在线综合色| 欧美连裤袜在线视频| 亚洲专区欧美专区| 久久国内精品视频| 日韩一区二区精品视频| 亚洲视频第一页| 在线看片一区| 一区二区三区高清在线观看| 国产一区二区三区电影在线观看| 欧美大片在线观看| 国产精品乱子久久久久| 免费黄网站欧美| 国产精品久久久久久亚洲调教 | 久久精品日韩| 久久久美女艺术照精彩视频福利播放| 亚洲激情电影中文字幕| 这里只有视频精品| 在线观看中文字幕不卡| 一区二区三区三区在线| 狠狠色丁香婷婷综合| 亚洲精品久久久蜜桃| 海角社区69精品视频| 99国产精品| 亚洲国产成人高清精品| 亚洲自拍偷拍一区| 99这里只有精品| 久久婷婷国产综合国色天香| 亚洲欧美在线一区二区| 欧美激情偷拍| 欧美二区在线观看| 国内免费精品永久在线视频| 一区二区精品国产| 亚洲精品影院| 免费在线亚洲欧美| 美女精品在线观看| 国内成人自拍视频| 校园激情久久| 性色av一区二区三区在线观看 | 国产一区二区你懂的| 亚洲美女黄网| 99re8这里有精品热视频免费| 久久久久.com| 美国十次了思思久久精品导航| 国产精品亚洲综合一区在线观看| 亚洲人成77777在线观看网| 亚洲高清av在线| 久久免费视频在线观看| 久久频这里精品99香蕉| 国产日韩欧美在线播放不卡| 这里只有精品视频在线| 在线亚洲国产精品网站| 欧美日韩国产页| 一区二区免费在线播放| 亚洲免费在线精品一区| 欧美视频一区二区三区| 亚洲精选在线| 亚洲一区二区视频在线观看| 欧美日韩日日骚| 一区二区三区日韩精品视频| 亚洲一区免费视频| 国产精品久久久久91| 亚洲欧美日韩一区| 久久久久国产一区二区三区| 一区二区三区在线视频播放| 久久久久综合网| 欧美在线日韩精品| 亚洲免费在线| 国产一区二区在线免费观看| 久久精品国产免费看久久精品| 久久精品在这里| 亚洲福利视频专区| 欧美另类videos死尸| 亚洲性线免费观看视频成熟| 欧美中文在线观看国产| 一色屋精品亚洲香蕉网站| 免费久久99精品国产| 欧美日韩国产一级片| 女人色偷偷aa久久天堂| 亚洲精品女人| 国产精品免费一区二区三区在线观看 | 狠狠色狠狠色综合日日91app| 久久精品视频亚洲| 亚洲欧洲中文日韩久久av乱码| 亚洲一二区在线| 国产一区自拍视频| 欧美大片91| 亚洲视频免费在线| 免费观看亚洲视频大全| 亚洲视频在线观看网站| 国产一区二区三区久久| 美腿丝袜亚洲色图| 一区二区三区久久| 免费欧美视频| 亚洲一级在线| 亚洲成色999久久网站| 欧美午夜电影在线| 久久这里有精品视频| 亚洲午夜免费视频| 欧美激情第一页xxx| 欧美一级理论性理论a| 亚洲人成网站影音先锋播放| 国产伦理一区| 欧美日韩一区二区欧美激情| 久久se精品一区精品二区| 亚洲人成在线免费观看| 久久久久国产一区二区| 亚洲午夜精品在线| 亚洲精品久久久久久一区二区 | 99精品国产在热久久下载| 国产精品一页| 欧美日韩在线精品| 蜜桃av一区二区| 欧美在线看片a免费观看| 亚洲视频欧洲视频| 日韩亚洲一区在线播放| 亚洲国产cao| 欧美激情欧美激情在线五月| 久久久久成人精品|