• <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>
            隨筆 - 119  文章 - 290  trackbacks - 0

            博客搬家了哦,請移步
            叫我abc

            常用鏈接

            留言簿(12)

            隨筆分類

            我的博客

            搜索

            •  

            積分與排名

            • 積分 - 304430
            • 排名 - 84

            最新評論

            閱讀排行榜

            估計標題和摘要都說不清楚,先直接用以前的一個demo說明一下多態(tài)吧。
            demo中有一個terrain類,代表地形,地形要做的工作就是調整player和enemy的高度,以便讓它們看起來是正確的站在地面上。
            負責這個工作的函數(shù)是CTerrain::Support(param),現(xiàn)在的問題是param的類型。在設定上,無論是terrain->support(player),或者terrain->support(enemy),Support函數(shù)內所做的調用是完全相似的。
            因此,第一直覺是,抽象出player和enemy的基類cast,并將被CTerrain::Support調用的函數(shù)寫成(純)虛函數(shù)。
            代碼大概是這樣子:

            class ??CCast
            {
            public :
            ??
            virtual ?? void ??DoSomething1()? = ? 0 ;
            ??
            virtual ?? void ??DoSomething2()? = ? 0 ;
            }
            ;
            class ??CPlayer?:? public ?CCast? {} ;
            class ??CEnemy?:? public ?CCast? {} ;

            class ??CTerrain
            {
            public :
            ??
            void ??Support(CCast? * cast)
            ??
            {
            ????cast
            -> DoSomething1();
            ????cast
            -> DoSomething2();
            ??}

            }
            ;

            接下來聊聊模板的表現(xiàn)。基于上面的代碼,把CCast類去掉,同時CPlayer和CEnemy類仍舊實現(xiàn)成員函數(shù)DoSomething1()和DoSomething2()。CTerrain類修改一下:
            class??CTerrain
            {
            public:
            ??template
            <typename?CAST>
            ??
            void??Support(CAST??*cast)
            ??
            {
            ????cast
            ->DoSomething1();
            ????cast
            ->DoSomething2();
            ??}

            }
            ;

            情況大概就是這樣子了,需要思考的是:
            1,模板是編譯時刻決定選擇,多態(tài)是runtime時刻決定選擇。那么,如果事務的環(huán)境允許編譯時刻決定選擇,采用模板方案是否更有意義?CEGUI在msg->handler的映射上采用了模板機制。
            2,多態(tài)有虛擬函數(shù)表的開銷,模板的實例化,同樣有類似于函數(shù)重載的開銷。不過,多態(tài)的開銷包括時間和空間上的,而模板僅僅是空間開銷。
            3,如果堅持用模板構建整個project,那么設計上就要抹去runtime時刻決定選擇的行為,這是否會增加程序復雜度,降低可擴展性?
            posted on 2006-12-20 15:37 LOGOS 閱讀(1195) 評論(3)  編輯 收藏 引用

            FeedBack:
            # re: 模版與多態(tài) 2006-12-20 20:09 pengkuny
            關注  回復  更多評論
              
            # re: 模版與多態(tài) 2006-12-21 14:48 Francis Arcanum
            如果不考慮在運行期間動態(tài)的增加邏輯的話,模板和虛函數(shù)其實是一樣的
            因為main不是模板函數(shù),同樣C++里new T也不能變成虛函數(shù)(因為沒有反射),兩種思路歸根結底都必須在一個點上進行switch或mapping。
            模板的問題在于,它缺乏一個統(tǒng)一的型別,因此在對模板對象進行持有的時候會有些困難。這個問題最后還是要靠虛函數(shù)來解決。  回復  更多評論
              
            # re: 模版與多態(tài) 2006-12-22 15:43 小山日志
            一個是運行時的動態(tài)多態(tài);一個是編譯時的靜態(tài)多態(tài)。
            一個是優(yōu)先使用高內聚的類來封裝數(shù)據(jù)和算法;一個是將算法和數(shù)據(jù)分別歸類,再以接口來使用,以此提高算法和容器的利用效率(這個是STL的做法,你提出的例子好像沒有體現(xiàn)出來^_^)。

            關于你提出的第三點,我以為那要看你的設計如何了。泛型和多態(tài)(動態(tài)的)其實目的都是提供高內聚、低耦合的設計方法,只是側重點不一樣啊  回復  更多評論
              
            亚洲美日韩Av中文字幕无码久久久妻妇| 久久久一本精品99久久精品66| 93精91精品国产综合久久香蕉| 久久精品国产精品亚洲艾草网美妙| 久久人妻少妇嫩草AV无码蜜桃| 亚洲综合日韩久久成人AV| 国产激情久久久久影院小草 | 久久天天躁狠狠躁夜夜不卡| 日韩乱码人妻无码中文字幕久久| 精品免费tv久久久久久久| 久久久久久极精品久久久 | 日韩精品久久久久久免费| 色综合久久综合网观看| 国产色综合久久无码有码| 97精品伊人久久久大香线蕉| 精品久久亚洲中文无码| 精品久久国产一区二区三区香蕉| 看久久久久久a级毛片| 亚洲伊人久久成综合人影院| 国内精品久久久久久久coent| 日韩精品久久无码中文字幕| 中文精品久久久久人妻| 久久精品99无色码中文字幕| 97久久超碰成人精品网站| 无码日韩人妻精品久久蜜桃 | 日本久久中文字幕| 欧美亚洲另类久久综合| 97久久国产亚洲精品超碰热 | 天堂久久天堂AV色综合| 久久久久久国产精品美女 | 久久亚洲AV成人无码| 人妻少妇精品久久| 青青草国产97免久久费观看| 久久精品国产99久久丝袜| 久久久99精品成人片中文字幕| 欧美精品一本久久男人的天堂| 久久精品国产91久久麻豆自制| 久久99国产精品久久久| 国产精品久久久久久搜索| 91麻精品国产91久久久久| 国产亚洲色婷婷久久99精品91|