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

            搜索

            •  

            積分與排名

            • 積分 - 52710
            • 排名 - 433

            最新評論

            閱讀排行榜

            評論排行榜

            [原創文章歡迎轉載,但請保留作者信息]
            Justin 于 2010-01-24

            前面已經學過,用虛函數來實現接口是再自然不過的事情。這里要說的是,除了直接單純使用虛函數機制,還有一些別的方法。

            大師說的第一種,是模板模式,利用非虛擬接口函數(Non-Virtual Interface, NVI)來實現。此模板(設計模式中的模板方法,template method)非彼模板(C++中的模板,template),而且也沒那么難:

            在父類中提供一個公有函數(接口),然后在其中調用真正干活的私有虛函數(默認實現);子類對象通過公有繼承自然得到了這個函數(接口),如果子類沒有編寫自己的實現版本,最終執行的就是默認的實現;如果子類實現了自己的版本,調用的就是子類的版本。(是不是和上節課的1.5有點親戚關系?)

            class ?AClass
            {
            ???
            public :
            ??????
            void ? interface ()
            ??????
            {
            ?????????printf(
            " in?base::interface()\n " );
            ?????????do_interface();
            ??????}

            ???
            private :
            ??????
            // the?default?implementation
            ?????? virtual ? void ?do_interface()
            ??????
            {
            ?????????printf(
            " in?AClass::do_interface()\n " );
            ??????}

            }
            ;

            class ?AClassDerived?:? public ?AClass
            {
            ???
            private :
            /* ?derived?can?has?its?own?implementation,?but?not?a?must..
            ??????virtual?void?do_interface()
            ??????{
            ?????????printf("in?AClassDerived::do_interface()\n");
            ??????}
            */

            }
            ;
            【給自己的】如果看到這里還會想:為什么是私有的虛函數?就搜“與大蝦對話:領悟設計模式”復習復習……

            看了第一種方法的大多數同學都會有這種想法:這不還是要用虛函數么?穿個wrapper的馬甲就認不出你了?大師馬上說
            第二個替代產品是策略模板(strategy pattern),利用函數指針實現:

            這種方法的實質,就是把接口函數的實現拿到了類之外。類之中只聲明接口的形式,只定義一個函數指針。真正干活的函數(實現)都不是類的成員。
            這樣做帶來了一定的靈活性,具體采用哪種實現與類的繼承關系是獨立無關聯的;同時,非類成員函數也有局限性:無法訪問類的非公有成員。如果把函數定義為友元或利用公有函數輸出私有成員,又會破壞原設計的
            封裝。如下代碼所示:

            class ?AClass
            {
            ???
            public :
            ??????typedef?
            void ? * (Interface)( /* param.. */ );
            ??????
            explicit ?AClass(?Interface?pint? = ?defaultInterface)?:?pInterface(pint)
            ??????
            {}
            ??????
            // ..
            ??? private :
            ??????Interface?pInterface;
            // ..
            }
            ;

            在構造AClass對象的時候即可指定Interface的真身,雖然,它無法直接訪問AClass的非公有成員。

            估計大師也覺得指針在C++里簡單一些,于是更推崇用C++的庫(如TR1中的function)來管理接口函數。

            原理和函數指針是一樣的,只不過因為用了對象來管理資源,使得應用更加靈活。當然,要付出更多一點的代碼體積和運行時間代價。

            class ?AClass
            {
            // ?all?are?the?same?with?the?funtion?pointer?version
            // ?except?for:
            ???typedef?std::tr1::function void ?( /* param.. */ ) > ?Interface;
            // ..
            }
            ;

            大師在最后才說出了最經典的策略模式實現,也是我覺得比較漂亮且容易理解的實現方式。

            用兩個類搞定:

            class ?AInterface
            {
            ???
            public :
            ??????
            // ..?
            ?????? virtual ? void ?DoInterface( /* ?param..? */ );
            ???
            // ..?
            };

            AInterface?defaultInterface;

            class ?AClass
            {
            ???
            public :
            ??????
            explicit ?AClass(AInterface? * ?pinter? = ? & defaultInterface)?:?pInter(pinter)
            ??????{}?
            ??????
            void ?TryInterface()
            ??????{
            ?????????pInter
            -> DoInterface();
            ??????}
            ???
            // ..?
            ??? private :
            ??????pInterface?
            * ?pInter;
            ???
            // ..?
            };

            看到最后,似乎本課的思想就是用模式設計(template pattern或strategy pattern)來代替簡單的虛函數設計。
            但是,大師臨走前又說了:以上只是舉例,為的是說明其實除了簡單的虛函數外,還有很多種可能的方式來替代它完成設計需要。

            posted on 2010-02-25 23:41 Justin.H 閱讀(513) 評論(0)  編輯 收藏 引用 所屬分類: Effective C++ 炒冷飯
            久久精品这里热有精品| 欧美激情精品久久久久久| 亚洲国产精品无码久久久蜜芽| 亚洲国产日韩综合久久精品| 亚洲女久久久噜噜噜熟女| 精品久久久久久久久午夜福利| 久久久久久久尹人综合网亚洲| 午夜视频久久久久一区| 久久精品中文闷骚内射| 久久久国产精品| 色综合久久无码五十路人妻| 亚洲狠狠综合久久| 无码日韩人妻精品久久蜜桃| 久久久久亚洲av成人无码电影 | 欧美久久久久久精选9999| 18岁日韩内射颜射午夜久久成人| 久久综合中文字幕| 狼狼综合久久久久综合网| 久久久黄色大片| 久久国产精品免费一区二区三区| 亚洲国产精品无码久久| 久久夜色撩人精品国产| 国产精品99久久精品爆乳| 久久国产精品无码一区二区三区| 精品久久久久成人码免费动漫| 久久精品草草草| 99re久久精品国产首页2020| 久久精品一区二区三区AV| 性高湖久久久久久久久AAAAA| 99久久精品免费看国产一区二区三区 | 久久久久人妻精品一区三寸蜜桃 | 国产精品免费久久久久久久久| 久久超乳爆乳中文字幕| 日韩AV无码久久一区二区 | 国产精品美女久久久久AV福利| 精品综合久久久久久97超人| 国产成人无码久久久精品一| 国内精品人妻无码久久久影院 | 久久久久国色AV免费看图片| 精品欧美一区二区三区久久久| 93精91精品国产综合久久香蕉|