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

            woaidongmao

            文章均收錄自他人博客,但不喜標題前加-[轉貼],因其丑陋,見諒!~
            隨筆 - 1469, 文章 - 0, 評論 - 661, 引用 - 0
            數據加載中……

            VC6不支持的模板特性

            1. 部分特化

             

            2. 模板嵌套(即template< template <... > >

             

            3. 模板參數形式匹配(不知道該用什么名字描述合適):

            template<typename TType> struct PtrType2Type;
            template<typename TType> struct PtrType2Type<TType *>
            {
                typedef TType Result;
            };

            第二行指定模板參數的形式必須是某個類型的指針。無法編譯通過。

             

            4. 從對常數型模板參數做推導時,該模板參數必須在模板參數列表的第一位:

            template<int Value>
            struct Int2Type
            {
                enum { value = Value };
            };

            template<int Index, class TType>
            void Test(TType &data, Int2Type<Index>)
            {

                cout << data << endl;
            }

            int main(int argc, char* argv[])
            {
                Test(1, Int2Type<0>());

                return 0;
            }

            上面的程序可以正常運行,輸出1。但如果把

            template<int Index, class TType>
            改成

            template<class TType, int Index>

            程序可以編譯通過,但運行時什么也不會輸出,看起來是

            Test(1, Int2Type<0>());

            這一行被直接忽略掉了!

             

            5. 模板成員函數的模板參數只能通過函數實參讓編譯器去推導,而不能顯示指定。

            struct SomeClass
            {
                template<class T>
                void Test(T & t)
                {
                }
            };

            int main(int argc, char* argv[])
            {
                SomeClass obj;
                obj.Test(2);

                return 0;
            }
            這樣是可行的。如果改成這樣:

             

            struct SomeClass
            {
                template<class T>
                void Test()
                {
                }
            };

            int main(int argc, char* argv[])
            {
                SomeClass obj;
                obj.Test<int>();

                return 0;
            }

            將無法編譯通過,編譯器提示 type 'int' unexpected

            如果再改成靜態成員函數,這樣:

             

            struct SomeClass
            {
                template<class T>
                static void Test()
                {
                }
            };

            int main(int argc, char* argv[])
            {
                SomeClass::Test<int>();

                return 0;
            }

            也無法編譯通過,而且是 NTERNAL COMPILER ERROR

             

             

            posted on 2008-11-13 14:25 肥仔 閱讀(2308) 評論(0)  編輯 收藏 引用 所屬分類: C++ 模板

            久久se精品一区二区| 国产精品乱码久久久久久软件| 久久免费看黄a级毛片| 久久久久国产精品嫩草影院| 婷婷久久久亚洲欧洲日产国码AV | 久久久久99精品成人片牛牛影视| 久久久久亚洲AV综合波多野结衣| 久久久久亚洲AV无码专区首JN | 欧美久久天天综合香蕉伊| 人妻无码精品久久亚瑟影视| 国产精品久久成人影院| 亚洲国产精品一区二区三区久久| 国产精品久久久久久吹潮| 久久亚洲国产精品五月天婷| 成人资源影音先锋久久资源网| 无码人妻少妇久久中文字幕| 亚洲成色999久久网站| 伊人久久无码中文字幕| 欧美精品一区二区久久 | 欧美激情精品久久久久久久| 国产成年无码久久久久毛片| 99久久做夜夜爱天天做精品| 亚洲国产精品久久久久网站 | 91久久精品电影| 国产精品一区二区久久国产| 亚洲狠狠婷婷综合久久蜜芽| 亚洲中文字幕伊人久久无码| 久久久久国色AV免费观看| 91麻豆精品国产91久久久久久| 99久久国产综合精品麻豆| 久久婷婷激情综合色综合俺也去| 色偷偷91久久综合噜噜噜噜| 久久99精品久久久久久噜噜| 天天久久狠狠色综合| 国产精品热久久毛片| 久久精品无码一区二区日韩AV| 激情久久久久久久久久| 久久国产V一级毛多内射| 国产精品美女久久久久av爽| 国产精品成人久久久久三级午夜电影| 亚洲午夜精品久久久久久人妖|