• <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
            數據加載中……

            C++模版全掌握(實例)

            前段時間重新學習C++,主要看C++編程思想和C++設計新思維。對模版的使用有了更進一層的了解,特總結如下:

            下面列出了模版的常用情況:
            //1. 模板類靜態成員
            template <typename T> struct testClass
            {
               
            static int _data;
            }
            ;
            template
            <> int testClass<char>::_data = 1;
            template
            <> int testClass<long>::_data = 2;
            int main( void ) {
                cout
            << boolalpha << (1==testClass<char>::_data) << endl;
                cout
            << boolalpha << (2==testClass<long>::_data) << endl;
            }
             

            //2. 模板類偏特化
            template <class I, class O> struct testClass
            {
                testClass()
            { cout << "I, O" << endl; } 
            }
            ;
            template
            <class T> struct testClass<T*, T*> 
            {
                testClass()
            { cout << "T*, T*" << endl; } 
            }
            ;
            template
            <class T> struct testClass<const T*, T*> 
            {
                testClass()
            { cout << "const T*, T*" << endl; } 
            }
            ;
            int main( void )
            {
                testClass
            <int, char> obj1;
                testClass
            <int*, int*> obj2;
                testClass
            <const int*, int*> obj3;
            }
             

            //3.類模版+函數模版
            template <class T> struct testClass
            {
               
            void swap( testClass<T>& ) { cout << "swap()" << endl; } 
            }
            ;
            template
            <class T> inline void swap( testClass<T>& x, testClass<T>& y )
            {
                x.swap( y );
            }
             
            int main( void )
            {
                testClass
            <int> obj1;
                testClass
            <int> obj2;
                swap( obj1, obj2 );
            }
             


            //4. 類成員函數模板
            struct testClass
            {
                template
            <class T> void mfun( const T& t )
               
            {
                    cout
            << t << endl;
                }
             
                template
            <class T> operator T()
               
            {
                   
            return T();
                }
             
            }
            ;
            int main( void )
            {
                testClass obj;
                obj.mfun(
            1 );
               
            int i = obj;
                cout
            << i << endl;
            }
             

            //5. 缺省模板參數推導
            template <class T> struct test
            {
                T a;
            }
            ;
            template
            <class I, class O=test<I> > struct testClass
            {
                I b;
                O c;
            }
            ;

            void main()
            {
            }



            //6. 非類型模板參數
            template <class T, int n> struct testClass {
                T _t;
                testClass() : _t(n)
            {
                }
             
            }
            ;
            int main( void ) {
                testClass
            <int,1> obj1;
                testClass
            <int,2> obj2;
            }
             


            //7. 空模板參數
            template <class T> struct testClass;
            template
            <class T> bool operator==( const testClass<T>&, const testClass<T>& )
            {
               
            return false;
            }
            ;
            template
            <class T> struct testClass
            {
                friend
            bool operator== <>( const testClass&, const testClass& );
            }
            ;
            void main()
            {
            }


            //8. template template 類
            struct Widget1
            {
            template
            <typename T> 
                T foo()
            {} 
            }
            ;

            template
            <template<class T>class X> 
            struct Widget2
            {
            }
            ;
            void main()
            {
                cout
            << 3 << '\n';
            }




            //參考:http://www.cnblogs.com/dayouluo/archive/2005/05/14/155092.html

            特別注意:類,全局函數,類的成員函數都可以特化,但是只有類可以半特化,全局函數和類的成員函數不可以半特化。
            //-------------------------------------------
            //1 類的特化和類成員函數的特化
            template<typename T>
            class Widget1
            {
            public:
               
            void Fun1()
               
            {
                   
            //generic implementation
                }

               
            }
            ;

            template
            <>
            class Widget1<int>
            {
            public:
               
            void Fun1()
               
            {
                }

            }
            ;
            template
            <> 
            void Widget1<char>::Fun1()
            {
               
            //specialization
            }


            void main()
            {

              Widget1
            <char> w;
              w.Fun1();
              Widget1
            <int> w2;
              w2.Fun1();
             
            }

            //-------------------------------------------
            //2 全局函數的特化和重載
            template<typename T1, typename T2>
            T1 Fun2(T2)
            {
            }


            //下面2個應該是屬于重載
            template<typename T2>
            char Fun2(T2)
            {
               
            char c;
               
            return c;
            }


            template
            <typename T1>
            T1 Fun2(
            char)
            {
            }


            //全局函數的特化
            template<>
            char Fun2<char,int>(int)
            {
               
            char c;
               
            return c;
            }

            int main()
            {
            }

            //-------------------------------------------
            //3 全局函數不能半特化,以下編譯失敗
            template <typename T1,typename T2> //原型1
            void Test(T1,T2)
            {
            }


            template
            <typename T1>
            void Test<T1,T1>(T1,T1)
            {
            }


            template
            <typename T1, typename T2> //原型2
            T1 Fun2(T2)
            {
            }

            //
            template<typename T2>
            int Fun2<int,T2>(T2)
            {
            }

            template
            <typename T1>
            T1 Fun2
            <T1,int>(int)
            {
            }

            template
            <typename T>
            T Fun2
            <T,T>(T)
            {
            }

            int main()
            {
            }



            ////-------------------------------------------
            ////4 類可以特化和半特化,但是特的成員函數像全局函數一樣,只能特化,不能半特化,

            template<typename T1, typename T2> struct Widget2
            {
             
            void Fun2()
             
            {
                 
            //generic implementation
              }

            }
            ;

            template
            <typename T2> 
            struct Widget2<char,T2>
            {
               
            void Fun2()
               
            {
                }

            }
            ;

            template
            <typename T2>
            struct widget2
            {
               
            void Fun2()
               
            {
                   
            // class partial specialization
                }

            }
            ;



            //the class member funtion can not be partial specialization
            //以下的成員函數半特化,編譯失敗
            template<typename T2>
            void Widget2<char, T2>::Fun2()
            {
               
            //class member function partial specialization
            }

            int main()
            {
            }

            參考:C++編程思想2

            posted on 2008-09-14 17:37 肥仔 閱讀(2100) 評論(0)  編輯 收藏 引用 所屬分類: C++ 模板

            香蕉久久av一区二区三区| 国产精品成人无码久久久久久| 九九精品久久久久久噜噜| 亚洲乱码精品久久久久..| 国产精品美女久久久久网| 色综合久久久久综合99| 久久久久亚洲AV无码专区体验| 久久99精品久久久久久野外| 蜜臀av性久久久久蜜臀aⅴ| 国产激情久久久久影院老熟女免费 | 久久伊人五月丁香狠狠色| 国产人久久人人人人爽| 无码乱码观看精品久久| 久久精品国产99久久无毒不卡| 性高朝久久久久久久久久| 99国产欧美久久久精品蜜芽| 国产亚洲精久久久久久无码77777| 久久99精品国产麻豆婷婷| 婷婷久久综合九色综合98| 久久影院综合精品| 久久国语露脸国产精品电影| 久久久噜噜噜久久| 一级做a爰片久久毛片人呢| 97精品久久天干天天天按摩| 一本色道久久88—综合亚洲精品| 久久精品www人人爽人人| 久久777国产线看观看精品| 久久久久99这里有精品10| 国产精品美女久久久网AV| 成人国内精品久久久久影院| 无码人妻精品一区二区三区久久久| 一级做a爰片久久毛片看看| 久久久久亚洲AV成人网| 久久久久国产精品麻豆AR影院 | 国产精品久久久久乳精品爆| 精品久久久久久无码专区| 欧洲成人午夜精品无码区久久| 中文字幕无码精品亚洲资源网久久| 久久久这里只有精品加勒比| 污污内射久久一区二区欧美日韩| 久久精品桃花综合|