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

隨筆-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| 欧美激情中文字幕乱码免费| 亚洲欧美国产精品桃花| 亚洲一区二区三区中文字幕| 亚洲特级片在线| 亚洲一区二区三区成人在线视频精品| 中文在线资源观看视频网站免费不卡| 亚洲视屏在线播放| 午夜在线视频观看日韩17c| 久久不射网站| 欧美 日韩 国产精品免费观看| 欧美精品手机在线| 国产伦精品一区二区三区| 国产一区二区三区免费不卡| 亚洲激情网址| 亚洲欧美在线高清| 美女精品国产| 99精品热6080yy久久| 欧美一区二区三区四区在线观看| 久久精品夜色噜噜亚洲a∨| 欧美电影电视剧在线观看| 国产精品久久久久久妇女6080| 国内外成人在线| 欧美激情视频一区二区三区不卡| 国产热re99久久6国产精品| 欧美国产精品专区| 久久精品99| 欧美成人精品1314www| 午夜精品视频在线观看| 香蕉久久一区二区不卡无毒影院| 欧美一区二区三区成人| 欧美激情免费在线| 欧美激情视频免费观看| 日韩视频永久免费观看| 欧美一区二区在线视频| 欧美尤物一区| 亚洲美女精品成人在线视频| 亚洲欧美成人| 亚洲高清视频一区二区| 亚洲视屏一区| 欧美日韩专区| 亚洲精品国精品久久99热一| 久久精品视频亚洲| 夜夜爽www精品| 欧美a级片网站| 黄色成人在线网站| 久久精品国产99国产精品| 99精品免费视频| 欧美韩日视频| 亚洲精品久久| 亚洲大胆人体在线| 久久精品中文字幕免费mv| 国产精品区二区三区日本| aa成人免费视频| 亚洲破处大片| 欧美激情第三页| 亚洲精品一区二区三区福利| 欧美激情按摩在线| 欧美1区2区视频| 亚洲电影专区| 亚洲国产日韩欧美综合久久 | 日韩视频一区二区三区在线播放免费观看| 久久久天天操| 亚洲高清免费视频| 欧美国产精品日韩| 欧美bbbxxxxx| 日韩午夜三级在线| 99精品视频免费观看视频| 久久综合久久综合这里只有精品| 欧美三日本三级少妇三2023| 亚洲精品小视频| 一区二区三区**美女毛片| 国产九九精品视频| 久热精品视频| 欧美片在线播放| 久久aⅴ国产欧美74aaa| 欧美激情精品久久久| 欧美伊久线香蕉线新在线| 国产一区二区三区四区老人| 久久精品中文字幕一区| 葵司免费一区二区三区四区五区| 亚洲电影网站| 99亚洲伊人久久精品影院红桃| 国产精品国内视频| 久久嫩草精品久久久精品| 欧美不卡一区| 欧美影院久久久| 裸体丰满少妇做受久久99精品| 美女网站久久| 国产日韩专区| 老司机免费视频一区二区三区| 久久伊伊香蕉| 午夜精品久久久久| 麻豆精品视频在线| 一区二区三区欧美成人| 欧美一区在线直播| 在线性视频日韩欧美| 久久九九久久九九| 亚洲视频一区二区| 久久九九免费视频| 亚洲欧美另类在线观看| 六月天综合网| 欧美一区影院| 欧美日本高清| 欧美成人黄色小视频| 国产精品美女视频网站| 欧美第一黄网免费网站| 国产美女搞久久| 99综合视频| 亚洲精品视频一区| 久久精品导航| 欧美亚洲一区| 欧美午夜女人视频在线| 欧美99久久| 国产综合第一页| 先锋影音国产一区| 午夜精品久久久久久久久久久| 欧美国产另类| 亚洲日韩成人| 欧美一区二区免费| 一区在线免费| 欧美日韩国产美| 久久精品国产一区二区电影 | 亚洲第一成人在线| 先锋影音国产一区| 国产精品video| 欧美国产日韩免费| 合欧美一区二区三区| 亚洲一区二区免费看| 亚洲一区二区免费| 欧美三级黄美女| 99精品欧美一区| 亚洲婷婷综合久久一本伊一区| 免费在线国产精品| 亚洲国产日韩欧美在线99 | 欧美视频网站| 99国产精品国产精品毛片| aa国产精品| 欧美日韩在线直播| 一区二区三区国产在线| 亚洲午夜久久久| 欧美午夜无遮挡| 亚洲一区精品视频| 欧美在线日韩| 一区二区在线观看视频在线观看| 一区二区三区在线视频播放| 亚洲一区网站| 小处雏高清一区二区三区| 国产精品黄视频| 亚洲午夜未删减在线观看| 亚洲一区免费看| 国产精品视频一二三| 亚洲欧美在线另类| 久久精品欧美日韩| 国外视频精品毛片| 久久在线免费观看| 亚洲第一综合天堂另类专| 亚洲精品男同| 欧美性大战久久久久久久蜜臀| 在线视频一区观看| 久久精品国产免费观看| 精品1区2区3区4区| 欧美精品色综合| 亚洲欧美日韩精品久久| 亚洲影视在线播放| 欧美精品久久99久久在免费线| 另类综合日韩欧美亚洲| 欧美日韩国产一中文字不卡| 黄色成人在线免费| 亚洲午夜电影在线观看| 久久激情久久| 91久久精品美女| 久久精品国产成人| 国产日韩欧美精品在线| 国内精品久久久久久久影视蜜臀 | 在线电影一区| 欧美激情网友自拍| 午夜亚洲性色福利视频| 亚洲成色777777女色窝| 性色一区二区| av成人老司机| 国产一区二区三区久久久久久久久 | 国产精品一区免费在线观看| 久久一区二区精品| 中文在线一区| 亚洲欧洲一区| 蜜桃av一区| 欧美在线免费一级片| 中国成人在线视频| 亚洲国产91色在线| 国产日本欧美视频| 欧美视频官网| 欧美美女视频| 欧美激情bt| 免费观看一级特黄欧美大片| 欧美影院成年免费版| 亚洲在线视频免费观看| 一区二区三区精密机械公司 | 亚洲伊人久久综合|