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

            關(guān)于工作和讀書的筆記

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

            留言簿(14)

            搜索

            •  

            積分與排名

            • 積分 - 53108
            • 排名 - 433

            最新評論

            閱讀排行榜

            評論排行榜

            [原創(chuàng)文章歡迎轉(zhuǎn)載,但請保留作者信息]
            Justin 于 2010-03-24


            首先看一個例子:
            templatetypename?T>
            class?TBase
            {
            ???
            public:
            ??????
            void?HeyIhaveOneMillionDollar();
            ??????
            void?HeyIOwnABenz();
            //..
            };

            template
            typename?T>
            class?Derived?:?public?TBaseT>
            {
            ???
            public:
            ??????
            void?DaddySays()
            ??????{
            ?????????
            //..
            ?????????HeyIOwnABenz();
            ?????????
            //..
            ??????}
            //..
            };

            這樣的代碼是通不過編譯的,問題在DaddySays()中調(diào)用的HayIOwnABenz():
            咋一看貌似很正常,Derived繼承了父類TBase,就應(yīng)該可以用老爸的資產(chǎn);可是問題在于這個老爸不簡單:TBase是模板類。對于模板類來說,有一種東西叫做模板的特化。(這里這里都有提到過)
            一言蓋之,個人認(rèn)為可以理解為模板的重載。比如說下面的一個“徹底的重載”,TBase的全特化:
            template<>
            class?TBasechar>
            {
            ???
            public:
            ??????
            void?WellIHaveOnlyOnePenny();
            };

            專為char類型全特化的TBase沒有了HeyIHaveOneMillionDollar()也沒有HeyIOwnABenz(), 只有一個WellIHaveOnlyOnePenny()。在這種情況下,Derived類中DaddySays()的實現(xiàn)就顯然有問題了:這個“重載”老爸的資產(chǎn)不是原來的那么富有了!
            于是,為了避免以上情況的發(fā)生,編譯器采取了保守的做法:不能通過編譯。

            完了,老爸都不可靠,俺還能靠誰……靠大師!大師在這個時候出現(xiàn)了,還指出了三條出路:
            1. 用->。
            templatetypename?T>
            class?Derived?:?public?TBaseT>
            {
            ???
            public:
            ??????
            void?DaddySays()
            ??????{
            ?????????
            //..
            ?????????this->HeyIOwnABenz();
            ?????????
            //..
            ??????}
            //..
            };

            2. 用using。
            templatetypename?T>
            class?Derived?:?public?TBaseT>
            {
            ???
            public:
            ??????
            using?TBaseT>::HeyIOwnABenz;
            ??????
            void?DaddySays()
            ??????{
            ?????????
            //..
            ?????????HeyIOwnABenz();
            ?????????
            //..
            ??????}
            //..
            };

            3.顯式聲明。大師補充說明這種方法最好不用,因為如果被調(diào)用的是虛函數(shù),那么如此顯式的聲明會使得虛擬機制的動態(tài)綁定失效。
            templatetypename?T>
            class?Derived?:?public?TBaseT>
            {
            ???
            public:
            ??????
            void?DaddySays()
            ??????{
            ?????????
            //..
            ?????????TBaseT>::HeyIOwnABenz();
            ?????????
            //..
            ??????}
            //..
            };

            問題得以解決,不過有點莫名其妙。個人認(rèn)為是用來唬編譯器用的:“我的“老爸”真的有這個接口!!”
            只有當(dāng)父類真的有提供相應(yīng)的接口,才不會有問題,否則還是過得了初一過不了十五@#¥%
            因為,如果真的有下面的程序,最后還是無法編譯通過。
            TBasechar>?PoorDaddy;

            PoorDaddy.DaddySays();?
            //?won't?compile,?as?PoorDaddy?don't?have?the?interface?named?HeyIOwnABenz()

            posted on 2010-03-29 08:02 Justin.H 閱讀(1852) 評論(1)  編輯 收藏 引用 所屬分類: Effective C++ 炒冷飯

            Feedback

            # re: 讀書筆記:Effective C++ 炒冷飯 - Item 43 訪問基類模板中的成員 2010-03-29 09:59 萌萌
            看來VC6.0 模版這方面真的不咋樣啊  回復(fù)  更多評論
              

            人妻无码精品久久亚瑟影视| 国产麻豆精品久久一二三| 亚洲欧洲中文日韩久久AV乱码| 久久午夜福利电影| 久久精品中文字幕无码绿巨人| 丁香五月综合久久激情| 欧美黑人激情性久久| 伊人久久综在合线亚洲2019| 综合久久久久久中文字幕亚洲国产国产综合一区首 | 久久久久高潮综合影院| 色综合久久最新中文字幕| 精品久久久久久无码不卡| 99久久国产免费福利| 久久久久人妻精品一区二区三区| 久久午夜综合久久| 91久久精品视频| 777米奇久久最新地址| 伊人伊成久久人综合网777| 久久久艹| 国产女人aaa级久久久级| 国产精品久久亚洲不卡动漫| 性欧美丰满熟妇XXXX性久久久| 精品国产青草久久久久福利 | 久久免费看黄a级毛片| 亚洲人成网站999久久久综合| 久久国产成人| 国产精品gz久久久| 国产精品嫩草影院久久| 久久91精品国产91久久麻豆| 久久精品欧美日韩精品| 人妻丰满AV无码久久不卡| 99精品国产综合久久久久五月天 | 久久久噜噜噜www成人网| 7777久久久国产精品消防器材| 午夜视频久久久久一区| 欧美麻豆久久久久久中文| 亚洲精品成人网久久久久久| 久久久久久久91精品免费观看| 麻豆久久久9性大片| 国产A三级久久精品| 久久精品九九亚洲精品|