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

Note of Justin

關于工作和讀書的筆記

  C++博客 :: 首頁 :: 聯系 :: 聚合  :: 管理
  47 Posts :: 0 Stories :: 45 Comments :: 0 Trackbacks

留言簿(14)

搜索

  •  

積分與排名

  • 積分 - 53229
  • 排名 - 433

最新評論

閱讀排行榜

評論排行榜

[原創文章歡迎轉載,但請保留作者信息]
Justin 于 2009-11-12

第十項所言無他,就是要記得定義拷貝運算符時要返回對象自身的引用(*this)。原因很簡單,你會有連著用=號的時候(a=b=c),如果不返回對象的引用這一串賦值式子就無法傳遞下去。

Item11說的也是拷貝運算符,不過側重點在使用=號對自身賦值的特殊情況(a=a)。再繼續下去之前Scott先是舉了個很傻的例子:一個賦值函數

class ?Bitmap? { // ..}

class ?Widget? {
// ..
private :
???Bitmap?
* pb;
}

???
Widget
&
Widget::
operator = ( const ?Widget & ?rhs)
{
???delete?pb;
???pb?
= ? new ?Bitmap( * rhs.pb);
???
return ? * this ;
}

這樣的一個傻傻賦值函數有兩個問題:
?? 1. 在自賦值的時候是要出事的。(在自賦值的時候:pb被釋放之后,緊接著就又被當作右值來構造新的對象……)
?? 2. 在發生異常的時候也是要出事的。(設想如果在new的過程中出錯然后拋出異常,結果就是我們的pb成了野指針:它指向一個已經delete了的內存空間,你無法再次delete它,也不能讀,因為你不知道你讀到的是什么@#¥%)

于是就有了以下應付自賦值的策略:

  1. 在函數入口檢查是否屬于自拷貝(例如:檢查指針是否指向同一片內存),如果是,啥也不干直接返回。否則屬于正常情況的拷貝。偷個懶,用書上的術語:這樣解決了self-assignment-unsafe的問題,但是沒能避免exception-unsafe。
  2. 第二種方法比較簡單,只是整理一下指令的順序。但是卻同時解決了自賦值和拋出異常帶來的問題。繼續無恥的抄寫代碼一段:
    Widget&
    Widget::
    operator=(const?Widget&?rhs)
    {
    ???Bitmap?
    *pOrig?=?pb;???????????????//?remember?original?pb
    ???pb?=?new?Bitmap(*rhs.pb);??????//?make?pb?point?to?a?copy?of?*pb
    ???delete?pOrig;???????????????????????? //?delete?the?original?pb
    ???return?*this;
    }
    這樣的做法在解決以上兩個問題的同時卻也降低了執行的效率:不論什么情況,這個賦值函數都要創建一個新的Bitmap對象。
    當然,Scott也辯證地道出了第一種方法的額外支出:判斷語句必然地引入了程序的分支(branch),于是指令的預取(prefetch)、緩沖(caching)、流水線處理(pipelining)的效率就會被降低。
  3. Copy And Swap。很深奧的樣子。實際上就是改賦值為交換。例子在下面:

    Widget&
    Widget::operator=(Widget?rhs)????//?rhs?is?a?copy?of?the?object
    {?????????????????????????????????????//?passed?in?—?note?pass?by?val
    ???swap(rhs);???????????????????????????//?swap?*this's?data?with
    ????????????????????????????????????? ??????
    //?the?copy's
    ???return?*this;
    }


    利用參數傳值,隱性的構造了一個Widget對象。然后將新對象和本對象中的數據成員交換,達到為本對象賦值的效果。新的臨時對象在跳出函數后自動銷毀。剛才說的兩個unsafe,都不會存在。
    不過又要回來說效率,我總覺得這樣開銷還是大了,無論什么時候都要構造新的對象。而且Scott本人也說用swap來完成賦值的做法有點邏輯混淆。不過他老人家也說了,這樣做很有可能讓編譯器生成更有效率的代碼(!!)沒有驗證過,暫且相信吧【等待論證的占位符】

最后要炒的是第12項,講的也還是拷貝運算符:如何保證在賦值/拷貝的時候能夠將所有的成員完整拷貝過去?對于簡單的數據成員,編譯器自動生成的拷貝函數可以保證一個不漏都幫你拷貝;如果是比較復雜的成員(比如說指向一片內存空間的指針),編譯器就沒有足夠的智商把這些成員拷貝到另外一個對象中去了。

自己動手豐衣足食,還是要自己寫。
然而人寫的東西終究還是會有各種問題,比如說:

  1. 在增加類成員以后有可能忘記更新拷貝函數(典型丟三落四……),顯然的結果就是新增加的數據成員沒有在拷貝函數中得到關照,拷貝不完全。
  2. 子類的拷貝函數把自己的成員都拷貝了,但是卻漏了把父類對象的成員拷貝到新的對象中。

第一個問題沒人能幫忙,只能靠自己小心。
第二個問題,方法比較直接了:在子類的拷貝函數中調用父類的拷貝函數(老爸,勞煩您也拷貝一下吧~~),代碼:

Widget &
Widget::
operator ? = ?(Widget?src)??
{
???swap(src);???????????????????????????????????
// copy-and-swap
???WidgetParent:: operator ? = ?(src);?????? // invoking?the?parent's?copy?assignment?operator
??? return ? * this ;
}


最后的最后,通常來說在拷貝函數和拷貝構造函數中的實現大多相同,大師就很貼心的提醒:不要在拷貝函數中調用拷貝構造函數或者反之。如果真的需要避免代碼的重復,大可定義一個私有的函數來負責前面兩者相同的部分。

posted on 2009-12-18 22:18 Justin.H 閱讀(1197) 評論(0)  編輯 收藏 引用 所屬分類: Effective 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>
            国产精品免费视频观看| 久色婷婷小香蕉久久| 国产日韩在线播放| 欧美婷婷在线| 国产精品尤物| 国产一区二区三区四区五区美女| 欧美日韩免费精品| 欧美日韩中文| 国产精品免费网站| 在线成人h网| 亚洲国产精品第一区二区| 最新亚洲激情| 欧美亚洲视频在线看网址| 美女脱光内衣内裤视频久久网站| 99re在线精品| 一区二区高清视频| 欧美激情在线观看| 欧美日韩成人综合在线一区二区| 亚洲精品中文字幕在线观看| 亚洲每日在线| 狠狠狠色丁香婷婷综合激情| 老司机午夜精品视频| 国产精品一区二区男女羞羞无遮挡| 欧美日韩国产大片| 艳妇臀荡乳欲伦亚洲一区| 久久精品人人做人人综合| 亚洲国产另类久久精品| 一区二区三区国产在线| 欧美精品久久久久久久| 亚洲国内在线| 欧美激情一区二区三区蜜桃视频| 亚洲一区尤物| 国产欧美69| 免费高清在线视频一区·| 久久婷婷蜜乳一本欲蜜臀| 在线观看中文字幕亚洲| 欧美成人伊人久久综合网| 久久久久久久欧美精品| 亚洲国产高清自拍| 亚洲成人在线网站| 国产精品www网站| 久久先锋资源| 亚洲欧美精品在线观看| 国产三级欧美三级日产三级99| 麻豆国产精品va在线观看不卡| 免费久久99精品国产| 狠久久av成人天堂| 欧美福利在线| 国产精品美女主播| 久久久久久夜| 欧美精品www| 午夜精品久久久久久久99黑人| 一区二区三区久久精品| 国产色视频一区| 亚洲人成网站777色婷婷| 国产精品久久久久久久久久尿| 免费久久99精品国产自| 欧美日韩成人在线视频| 国产目拍亚洲精品99久久精品| 久久偷窥视频| 欧美亚州韩日在线看免费版国语版| 久久亚洲影音av资源网| 国产精品一区二区在线| 日韩视频免费| 亚洲精品一区中文| 久久婷婷综合激情| 久久综合一区二区| 国产偷自视频区视频一区二区| 欧美精品成人| 久久激情五月丁香伊人| 国产精品久久久久久久久免费樱桃| 亚洲精品你懂的| 亚洲精品网站在线播放gif| 久久久综合精品| 久久亚洲国产精品日日av夜夜| 国产欧美日韩高清| 久久综合九色综合网站| 亚洲精品小视频| 欧美亚洲一区二区在线观看| 国产精品成人一区| 久久久久久久性| 中文在线资源观看网站视频免费不卡| 欧美在现视频| 亚洲色无码播放| 亚洲黄色毛片| 影音先锋欧美精品| 国内精品久久久久久| 欧美日韩情趣电影| 欧美成人嫩草网站| 欧美高清免费| 亚洲欧美电影在线观看| 欧美日韩国产高清| 久久久久国色av免费看影院| 免费看成人av| 先锋资源久久| 亚洲综合大片69999| 亚洲人成亚洲人成在线观看| 亚洲黄色有码视频| 亚洲欧洲一区二区三区在线观看 | 国产精品高潮呻吟久久| 欧美一区二区三区另类| 国产精品国产成人国产三级| 久久久久九九九九| 欧美一区亚洲二区| 亚洲欧美日韩精品久久亚洲区 | 久久夜色精品亚洲噜噜国产mv| 亚洲日本视频| 亚洲成人在线免费| 亚洲国产91色在线| 亚洲人成网站在线观看播放| 激情久久综艺| 亚洲国产91精品在线观看| 一区二区在线观看av| 黄色成人在线观看| 在线观看成人小视频| 亚洲激情电影在线| 亚洲精品综合| 亚洲先锋成人| 欧美一区免费视频| 久久久亚洲人| 欧美好吊妞视频| 夜夜嗨av色一区二区不卡| 亚洲欧美精品在线观看| 久久久久久久国产| 欧美日韩亚洲另类| 激情自拍一区| 欧美亚洲一区二区在线观看| 久久婷婷国产麻豆91天堂| 亚洲高清视频在线| 香蕉久久夜色精品国产| 免费观看在线综合| 国产日产亚洲精品| 一本大道av伊人久久综合| 国产精品毛片va一区二区三区| 国产精品日韩高清| 正在播放欧美一区| 久久久久国产一区二区三区四区 | 欧美一区二区高清| 欧美成人免费在线| 久久精品国产一区二区电影| 欧美激情精品久久久| 一色屋精品视频在线观看网站| 亚洲一区在线免费观看| 另类国产ts人妖高潮视频| 国产欧美日韩精品在线| 亚洲女女做受ⅹxx高潮| 亚洲美女色禁图| 欧美精品少妇一区二区三区| 亚洲激情中文1区| 亚洲高清二区| 欧美精品一卡| 亚洲欧美日韩国产综合| 日韩亚洲欧美成人| 国产精品视频网| 久久成人精品| 嫩草国产精品入口| 一区二区三区国产在线| 亚洲调教视频在线观看| 国产精品系列在线| 久久久久久999| 免费欧美日韩国产三级电影| 日韩视频精品在线观看| 亚洲午夜精品久久| 黄色一区二区在线观看| 亚洲剧情一区二区| 国产日韩一区二区三区在线| 久久久www成人免费毛片麻豆| 久久亚洲私人国产精品va媚药| 亚洲精品乱码久久久久久蜜桃91| 亚洲婷婷在线| 最近中文字幕mv在线一区二区三区四区| 91久久久在线| 精品福利免费观看| 亚洲一区综合| 一区二区三区欧美成人| 久久久久久精| 国产精品sm| 亚洲丶国产丶欧美一区二区三区 | 久久一区二区三区超碰国产精品| 欧美aa在线视频| 猛男gaygay欧美视频| 国产亚洲激情视频在线| 亚洲人成在线观看| 亚洲精品午夜| 欧美日韩国产a| 欧美激情aaaa| 日韩视频在线观看| 久久国产精品久久久久久电车| 国产精品国产三级国产aⅴ浪潮| 美女尤物久久精品| 久久精品网址| 伊人久久成人| 模特精品在线| 一本久久a久久精品亚洲| 在线视频亚洲| 国产精品一区二区三区免费观看| 夜夜夜精品看看| 久久免费视频在线观看| 狠狠色狠狠色综合日日小说| 久久婷婷国产综合国色天香|