• <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>

            Note of Justin

            關于工作和讀書的筆記

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

            留言簿(14)

            搜索

            •  

            積分與排名

            • 積分 - 52711
            • 排名 - 433

            最新評論

            閱讀排行榜

            評論排行榜

            [原創文章歡迎轉載,但請保留作者信息]

            Justin 于 2010-01-21

            Scott 開篇就直接說開了: C++ 陣營中關于多重繼承 (Multiple Inheritance, MI) 分成了兩派,一派認為多重繼承比單一繼承好,另外一邊則認為弊大于利。

            所以本課的內容就是說說 MI 的優與劣。

            MI 的第一個問題就是名字沖突, 最經典的例子就是鉆石問題 (diamond problem)。
            設想 A 中有一個函數叫做 GetName() B C 中都將有這一函數成員,這個時候 D :: GetName() 的真正實現是來自 B 的還是 C 的呢?二義性出現了 (ambiguity)

            不過如果真的發生了這種情況,要解決的方法也不是沒有,可以這樣做:

            D?d;
            d.B::GetName();?
            //Calling?B's?implementation

            嗯,很容易理解。

            另外一個高階一點的方法叫做虛繼承 (virtual inheritance) 。對于在虛擬繼承中的父類,其中的成員都保證不會在后面的子類中出現二義現象 (ambiguity) 。似乎是專門為了 MI 才整出來的,汗 ……

            例子還是已前面的鉆石問題:

            class?A
            {
            ???
            public:
            ??????
            void?GetName();
            //..
            };

            class?B?:?virtual?public?A
            {
            //..
            };

            class?C?:?virtual?public?A
            {
            //..
            };

            class?D?:?public?B,?public?C
            {
            //..
            }

            D?d;
            d.GetName();?
            //there?is?no?ambiguity?here.

            但是虛繼承不是沒有代價的,大師說這種技術會使得最終代碼變得更大,訪問虛擬繼承中的父類成員也會變得更慢一些。

            這個也不難理解。和空間換時間一樣,和不給牛吃草牛就不干活一樣。 ( 另外的一個代價我還沒能完全理解透徹:書上說因為虛繼承中基類的初始化是由繼承關系中最底層的子類負責的,因此對于這些最底下的 嫡孫 類來說,就不是那么方便了 )

            于是大師建議只有在必要的時候才使用虛繼承,而在虛繼承中的基類里也不要放置數據成員,這樣就不用擔心初始化的問題了。

            不過存在就是合理,還是有需要用到 MI 的時候。一個在書中提到的使用 MI 的情形是:當需要從一個類 AClass 中繼承接口,又需要從另外一個類 BClass 中繼承實現細節時,就可以考慮在公有繼承 AClass 的同時又私有繼承 BClass 。道理大致就是這樣,就不編造程序畫蛇添足了。

            總結一下: MI SI(Single Inheritance) 要復雜容易出錯 ( 比如說鉆石問題 ) ,即使可以用虛繼承來解決鉆石問題,但是其帶來的代碼體積增大,訪問效率下降以及初始化問題還是不能忽視的。最后話說回來,需要用到 MI 的時候,小心點用便是 @# %

            【參考】 http://en.wikipedia.org/wiki/Virtual_inheritance

            posted on 2010-03-15 09:18 Justin.H 閱讀(384) 評論(0)  編輯 收藏 引用 所屬分類: Effective C++ 炒冷飯
            亚洲伊人久久综合中文成人网| 久久精品成人| 伊人久久大香线蕉成人| a高清免费毛片久久| 99久久人妻无码精品系列蜜桃| 中文字幕人妻色偷偷久久| 亚洲va国产va天堂va久久| 亚洲精品乱码久久久久久中文字幕 | 99久久国产综合精品女同图片| 色综合久久天天综线观看| 色婷婷狠狠久久综合五月| 久久人与动人物a级毛片| 精品久久人妻av中文字幕| 久久精品国产福利国产秒| 久久伊人影视| 潮喷大喷水系列无码久久精品| 久久免费精品视频| 香蕉久久夜色精品国产尤物| 无码人妻少妇久久中文字幕蜜桃 | 无码国内精品久久综合88| 久久A级毛片免费观看| 国产精品久久久99| 久久久久亚洲精品日久生情 | .精品久久久麻豆国产精品| 亚洲综合婷婷久久| 亚洲综合伊人久久综合| 国产高清国内精品福利99久久| 久久久久亚洲国产| 精品久久久无码中文字幕| 久久久久久久久无码精品亚洲日韩 | 欧美日韩久久中文字幕| 国产69精品久久久久777| 一本色综合久久| 免费观看成人久久网免费观看| 色8激情欧美成人久久综合电| 久久天天躁狠狠躁夜夜网站| 手机看片久久高清国产日韩| 精品永久久福利一区二区| 久久伊人精品一区二区三区| 欧洲性大片xxxxx久久久| 国产精品无码久久四虎|