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

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>
            久久久久这里只有精品| 亚洲国产乱码最新视频| 久久国产福利国产秒拍| 黄色另类av| 欧美福利一区二区| 亚洲麻豆视频| 久久久www| 亚洲免费视频中文字幕| 精品成人乱色一区二区| 欧美日韩在线观看视频| 欧美在线影院在线视频| 亚洲国产欧洲综合997久久| 欧美va日韩va| 久久久99精品免费观看不卡| 久久在线播放| 欧美在线关看| 亚洲欧美日韩另类| 久久久一区二区三区| 欧美成人中文| 欧美一区二区在线| 可以看av的网站久久看| 欧美夜福利tv在线| 一区二区三区精品视频| 在线观看欧美激情| 国产一区高清视频| 欧美四级电影网站| 欧美国产免费| 国产精品一区二区在线| 国产精品久久午夜| 欧美日韩精品不卡| 欧美日韩高清在线播放| 国产精品免费一区豆花| 精品96久久久久久中文字幕无| 亚洲欧洲视频| 亚洲精品乱码视频| 国内久久视频| 欧美日韩岛国| 亚洲一二区在线| 在线观看福利一区| 亚洲精品一区二区三区樱花| 亚洲综合成人在线| 亚洲免费在线看| 欧美激情视频网站| 亚洲国产成人精品视频| 另类亚洲自拍| 一区二区三区产品免费精品久久75 | 一区二区免费看| 久久亚洲一区二区| 午夜在线不卡| 久久高清福利视频| 久久精品网址| 美国十次了思思久久精品导航| 欧美在线观看一二区| 欧美色视频日本高清在线观看| 亚洲国产另类精品专区 | 欧美三级第一页| 最新69国产成人精品视频免费| 久久久久久九九九九| 亚洲欧美综合另类中字| 久久久蜜桃精品| 免费欧美在线视频| 欧美视频日韩视频在线观看| 亚洲激情网站免费观看| 欧美.www| 免费视频一区| 亚洲精品系列| 亚洲日本国产| 久久爱91午夜羞羞| 国产一区二区三区久久久| 亚洲精品网址在线观看| 亚洲国产片色| 欧美日韩国语| 亚洲欧美国产高清| 亚洲欧美在线一区二区| 国产视频欧美| 中国日韩欧美久久久久久久久| 欧美一级欧美一级在线播放| 亚洲线精品一区二区三区八戒| 久久九九国产| 亚洲国产欧美另类丝袜| 亚洲人成网站影音先锋播放| 欧美日韩无遮挡| 亚洲欧美日韩精品久久亚洲区| 亚洲欧美国产精品桃花| 欧美国产综合视频| 亚洲一二三区在线| 欧美一级视频免费在线观看| 欧美日韩一区在线视频| 国产精品自拍在线| 欧美精品久久久久久久久老牛影院 | 一区在线影院| 亚洲国产国产亚洲一二三| 欧美日韩国产限制| 久久大综合网| 欧美mv日韩mv亚洲| 午夜精品国产更新| 亚洲美女网站| 欧美大片va欧美在线播放| 国产亚洲一区二区三区在线观看 | 亚洲精品免费在线观看| 一本一本久久a久久精品牛牛影视| 国产精品中文在线| 欧美高清在线视频| 国产精品爽爽ⅴa在线观看| 宅男在线国产精品| 欧美一级视频一区二区| 日韩视频在线一区| 欧美成人网在线| 欧美日韩综合视频| 久久综合色播五月| 国产精品久久久久久久电影 | 午夜精品一区二区三区四区| 一区二区三区在线看| 中文在线资源观看视频网站免费不卡| 欧美激情视频免费观看| 久久激情久久| 欧美在线免费一级片| 一区二区三区欧美在线| 久久婷婷一区| 91久久国产自产拍夜夜嗨| 亚洲欧美国产制服动漫| 日韩网站在线看片你懂的| 久久er精品视频| 欧美一级艳片视频免费观看| 欧美激情一区三区| 免费精品视频| 欧美日韩在线视频首页| 欧美激情视频在线免费观看 欧美视频免费一 | 国产午夜精品久久久久久免费视| 亚洲裸体视频| 中国亚洲黄色| 国产精品都在这里| 这里只有精品视频| 亚洲图片在线观看| 欧美日韩亚洲一区三区 | 欧美国产精品一区| 亚洲电影欧美电影有声小说| 怡红院精品视频| 欧美色道久久88综合亚洲精品| 亚洲欧美视频在线观看视频| 一本色道久久综合亚洲精品不卡 | 亚洲图中文字幕| 在线视频亚洲| 欧美午夜在线| 免费观看成人www动漫视频| 国产一区二区三区久久悠悠色av | 欧美亚洲免费电影| 欧美专区一区二区三区| 国产丝袜一区二区| 久久久久久日产精品| 欧美大片18| 一本色道久久88综合亚洲精品ⅰ| 欧美日韩黄色大片| 亚洲性图久久| 久久久久久久久久看片| 亚洲国产精品精华液2区45| 中文亚洲欧美| 性色av一区二区三区在线观看| 国产欧美一区二区精品忘忧草| 欧美大片va欧美在线播放| 亚洲国产精品va在线看黑人动漫 | 亚洲欧美日韩国产综合在线| 国产精品一二三四区| 欧美综合第一页| 亚洲国产成人久久| 亚洲一区二区三区四区五区黄| 国产精品电影观看| 久久久欧美精品| 亚洲精品日韩精品| 欧美在线视频观看| 亚洲国产小视频在线观看| 欧美日韩在线视频首页| 久久精品国产欧美亚洲人人爽| 亚洲国产精品www| 性做久久久久久久免费看| **欧美日韩vr在线| 久久久福利视频| 亚洲精品黄色| 久久手机精品视频| 亚洲图片欧美一区| 亚洲欧洲免费视频| 国产欧美日韩在线视频| 嫩草国产精品入口| 小嫩嫩精品导航| 日韩视频在线一区二区三区| 久久久久久久国产| 亚洲欧美日韩综合aⅴ视频| 亚洲国产欧美在线人成| 国产毛片久久| 欧美日产国产成人免费图片| 久久精品国产清自在天天线| 日韩一二三区视频| 欧美成年人视频网站| 久久er99精品| 亚洲一级免费视频| 亚洲精品一区二区三区婷婷月| 国内精品免费在线观看| 国产精品免费视频xxxx| 欧美日韩国产经典色站一区二区三区| 久久久精品一区二区三区|