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

            牧光小院

            被約束的日日夜夜,停不下來的時間。

            C++的靜態分派技術

            我們可以用不同的整數來實例化同一個模板,從而構造不同的類型,進而在編譯期執行某些抉擇。


            Alexandrescu 最初設計的一個簡單的模版,現在成了泛型設計的常用手法:

            template <int v>

            struct Int2Type {

            ??? enum { value? = v };

            };

            對于每一個不同的常整數, Int2Type 都代表不同的類型。這是因為不同的模版實例化都代表不同的類型,也就是說 Int2Type<0> Int2Type<1> 是完全不同的。

            當你想根據編譯時結果來進行某些抉擇——例如選擇不同的函數——時,你可以依賴一個常整數來幫你完成分派工作,這時 Int2Type 便可以幫你是實現這個方法。

            一般來說,你在下面兩個情況中需要使用 Int2Type

            l ???????? 你需要根據編譯時常量來調用不同的函數

            l ???????? 你需要在編譯時執行分派工作

            如果是在運行時執行分派工作,你可以用 if-else switch 語句來簡單的實現。在大部分的時候,這種運行時成本都是微不足道的。但是,有時它們卻不能滿足你的要求。既是是在編譯期可以決定其分支,編譯器還是會勤勞的為你編譯其所有的分支,這也就意味著 if-else 的所有分支必須被成功編譯。有些困惑?繼續看下去:

            考慮下面的情形:你設計了一個泛型容器 NiftyContainer

            template <class T> class NiftyContainer {

            ??? ...

            };

            NiftyContainer 容器包含指向 T 對象的指針。為了復制 NiftyContainer 中的一個對象,你可能需要調用 T 的拷貝構造函數(對于非多態類型)或者一個名為 Clone() 的虛函數(對于多態類型)。你可以通過設置一個 bool 類型的模版參數來從類的客戶手里獲得關于多態的信息。

            template <class T, bool isPolymorphic> class NiftyContainer {

            ??? // Other actions

            ??? void DoSomething() {

            ?????? T* pSomeObj = ...;

            ?????? if(isPolymorphic) {

            ?????????? T* pNewObj = pSomeObj->Clone();

            ?????????? // Some polymorphic algorithm

            ?????? }

            ?????? else {

            ?????????? T* pNewObj = new T(*pSomeObj);

            ?????????? // Some non-polymorphic algorithm

            ?????? }

            ??? }

            };

            問題在于編譯器不會讓你僥幸編譯上面的代碼。例如,如果一個多態類型沒有定義 Clone() ,那么 NiftyContainer::DoSomething 絕對不會通過編譯。盡管在編譯時我們肯定可以對于分支進行判斷,但這畢竟不是編譯器的工作,他只會勤勞的為你編譯出所有的代碼。于是當你試圖調用 NiftyContainer<int, false>::DoSomething 的時候,編譯器還是會停在 pObj->Clone() 上,并且抱怨說:“你在做什么?”

            對于非多態類型分支,也有可能發生編譯錯誤。如果 T 是一個多態類型,并且把它的拷貝構造函數設定為 private 的時候(這時一個多態類的良好行為),非多態分支的 new T(*pObj) 就會發生錯誤。

            你可能會想,如果編譯器可以不去理會那些不必要的分支就好了,但是看來不太可能。那么,如何是好呢?

            其實,方法有很多, Int2Type 提供了一個簡潔的辦法。它可以根據 true false 來生成兩個不同的類型,而后根據 Int2Type<isPolymorphic> 評估正確的調用。

            template <class T, bool isPolymorphic> class NiftyContainer {

            private :

            ??? // Other actions

            ??? void DoSomething(T* pObj, Int2Type<true>) {

            ?????? T* pNewObj = pSomeObj->Clone();

            ?????? // Some polymorphic algorithm

            ??? }

            ??? void DoSomething(T* pObj, Int2Type<false>) {

            ?????? T* pNewObj = new T(*pSomeObj);

            ?????? // Some non-polymorphic algorithm

            ??? }

            public :

            ??? void DoSomething(T* pObj) {

            ?????? DoSomething(pObj, Int2Type<isPolymorphic>());

            ??? }

            };

            當你想把常整數用作一個類型的時候, Int2Type 是非常方便的。你可以傳遞一個臨時的變量來重載函數。而之所以我們可以這樣做,是因為編譯器不會去編譯沒有用到的模板函數。

            posted on 2005-11-11 11:42 nacci 閱讀(2394) 評論(2)  編輯 收藏 引用 所屬分類: C++漫談

            評論

            # re: C++的靜態分派技術 2005-11-15 16:36 christanxw

            這在STL中有著廣泛的應用  回復  更多評論   

            # re: C++的靜態分派技術 2008-07-25 09:58 tomlau

            真好,學習了  回復  更多評論   

            <2008年7月>
            293012345
            6789101112
            13141516171819
            20212223242526
            272829303112
            3456789

            導航

            統計

            常用鏈接

            留言簿(2)

            隨筆分類

            收藏夾

            大家的聲音

            積分與排名

            最新評論

            閱讀排行榜

            評論排行榜

            久久WWW免费人成—看片| 久久无码人妻精品一区二区三区| 精品国产乱码久久久久久人妻| 国产A级毛片久久久精品毛片| 浪潮AV色综合久久天堂| 日韩一区二区久久久久久| 手机看片久久高清国产日韩 | 亚洲国产精品无码久久一线| 精品久久人妻av中文字幕| 99久久精品免费观看国产| 亚洲中文字幕久久精品无码喷水| 国产精品久久精品| 久久精品中文无码资源站| 99热成人精品免费久久| 久久久久久九九99精品| 一本久久综合亚洲鲁鲁五月天| 欧美精品久久久久久久自慰| 欧美午夜A∨大片久久| Xx性欧美肥妇精品久久久久久| 久久久久久午夜成人影院| 久久精品国产亚洲AV久| 国产成人精品久久综合| 国内精品久久久久| 欧美午夜精品久久久久免费视| 性做久久久久久久久浪潮| 久久久久一级精品亚洲国产成人综合AV区 | 久久久久av无码免费网| 国产精品一区二区久久精品| 亚洲国产精品18久久久久久| 国产高清国内精品福利99久久| 亚洲AV无码久久寂寞少妇| 久久综合九色综合网站| 偷偷做久久久久网站| 一日本道伊人久久综合影| 无码乱码观看精品久久| 久久无码精品一区二区三区| 国内精品久久久久久久影视麻豆 | 久久精品国产亚洲欧美| 国产99久久九九精品无码| 国产日韩久久久精品影院首页 | 色偷偷888欧美精品久久久|