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

隨筆-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| 亚洲日本中文字幕| 国产精品一卡二卡| 久久综合精品国产一区二区三区| 久久久久久国产精品mv| 亚洲三级网站| 亚洲女人小视频在线观看| 激情久久久久| 亚洲精品日韩在线| 国产亚洲美州欧州综合国| 麻豆精品91| 欧美日韩三区| 久久久久九九九九| 欧美日韩国产一区| 久久精品国产免费| 欧美理论在线| 快she精品国产999| 国产精品xnxxcom| 久久亚洲欧美| 国产精品v欧美精品v日本精品动漫| 久久久亚洲一区| 国产精品久久九九| 亚洲国产高潮在线观看| 国产精品久久久久999| 欧美88av| 国产亚洲视频在线| 99精品99久久久久久宅男| 在线成人中文字幕| 校园激情久久| 亚洲一级二级在线| 欧美电影在线| 美日韩丰满少妇在线观看| 伊人成综合网伊人222| 久久综合国产精品| 欧美日韩午夜激情| 免费成人美女女| 国产精品自拍视频| 一区二区成人精品| 亚洲卡通欧美制服中文| 久久久7777| 久久精品二区| 国产精品爽爽爽| 亚洲最快最全在线视频| 亚洲精品乱码久久久久久按摩观| 欧美专区日韩视频| 免费成人黄色| 免费不卡在线视频| 在线成人免费观看| 久久亚洲电影| 六月婷婷一区| 精品88久久久久88久久久| 亚洲一区自拍| 欧美一区二区三区在线观看视频| 欧美日韩综合另类| 一道本一区二区| 亚洲欧美日韩一区二区三区在线| 欧美视频一区二区三区在线观看 | 国产精品日韩欧美| 中国成人亚色综合网站| 亚洲伊人观看| 国产美女精品视频免费观看| 亚洲香蕉网站| 久久av一区二区三区| 国产一区二区三区免费不卡 | 欧美多人爱爱视频网站| 亚洲国产二区| 欧美精品一区二区三区蜜桃 | 亚洲国产成人av好男人在线观看| 尤物在线精品| 欧美大片在线看| 99精品视频免费全部在线| 亚洲欧美日韩视频一区| 国模吧视频一区| 欧美 日韩 国产在线 | 久久久在线视频| 在线精品一区| 欧美日韩精品在线观看| 在线综合亚洲欧美在线视频| 欧美有码视频| 亚洲国产欧美一区二区三区同亚洲| 欧美激情女人20p| 中文在线资源观看网站视频免费不卡 | 伊人成人在线| 欧美日韩在线电影| 欧美一级成年大片在线观看| 久久一区亚洲| 亚洲婷婷免费| 国产一区深夜福利| 欧美电影在线观看完整版| 亚洲一级在线| 亚洲国产精品成人va在线观看| 欧美成人精品1314www| 国产乱码精品一区二区三区av| 久久国产精品免费一区| 亚洲黄色成人| 欧美在线视频全部完| 亚洲人午夜精品| 国内成人精品2018免费看| 欧美日韩免费观看一区三区| 欧美制服丝袜| 中日韩美女免费视频网址在线观看 | 亚洲第一区中文99精品| 国产精品国产成人国产三级| 久久综合狠狠| 午夜亚洲性色福利视频| 亚洲人成在线播放| 狂野欧美激情性xxxx| 亚洲欧美日韩高清| 99在线|亚洲一区二区| 亚洲国产第一页| 国产一区二区三区在线免费观看| 欧美日韩高清在线| 免费观看在线综合| 久久精品国产久精国产爱| 中文av一区特黄| 亚洲美女网站| 亚洲国产日韩在线一区模特| 久久这里有精品15一区二区三区| 性色av香蕉一区二区| 亚洲视频1区| 亚洲最新中文字幕| 亚洲免费成人| 亚洲福利国产精品| 国产综合一区二区| 国产三区二区一区久久| 国产精品素人视频| 国产精品免费小视频| 欧美小视频在线| 欧美色大人视频| 欧美网站大全在线观看| 欧美日韩国产黄| 欧美日韩国产区一| 欧美性猛交一区二区三区精品| 欧美精品成人91久久久久久久| 噜噜噜噜噜久久久久久91| 久久久久久69| 久久―日本道色综合久久| 久久久久久久综合狠狠综合| 久久福利电影| 久久亚洲综合色一区二区三区| 久久爱另类一区二区小说| 久久精品一区二区| 久久一区精品| 欧美二区在线看| 欧美日韩免费观看一区| 欧美视频精品在线| 国产欧美一区二区三区另类精品 | 免费亚洲电影在线观看| 欧美国产精品中文字幕| 欧美午夜久久| 国产日韩欧美一区二区| 黄网站色欧美视频| 亚洲三级视频| 午夜精品影院| 美女露胸一区二区三区| 亚洲欧洲精品天堂一级| 中日韩高清电影网| 久久久91精品国产一区二区精品| 欧美成人国产一区二区| 欧美午夜美女看片| 国内精品视频在线播放| 亚洲娇小video精品| 亚洲在线播放电影| 久久一区二区三区四区五区| 欧美国产一区二区在线观看 | 国产精品高清一区二区三区| 国产综合色在线| 亚洲精品资源美女情侣酒店| 亚洲欧美日韩国产一区| 久久综合国产精品| 9人人澡人人爽人人精品| 久久国产日韩| 欧美日韩国产91| 激情综合电影网| 亚洲视频一二区| 美国十次成人| 亚洲午夜女主播在线直播| 麻豆成人精品| 国产欧美日韩亚洲一区二区三区 | 国产精品久久久久999| 亚洲国产第一页| 久久激情综合网| 日韩亚洲精品视频| 麻豆精品传媒视频| 国产欧美综合在线| 99亚洲一区二区| 欧美激情一区在线观看| 欧美一级在线播放| 国产精品av一区二区| 99pao成人国产永久免费视频| 久久天天躁狠狠躁夜夜av|