• <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 肥仔 閱讀(2098) 評論(0)  編輯 收藏 引用 所屬分類: C++ 模板

            99久久精品影院老鸭窝| 国内精品久久久久久久coent| 久久人人爽人人爽人人片AV麻豆 | 久久精品国产亚洲AV无码麻豆| 亚洲国产一成人久久精品| 成人综合久久精品色婷婷| 久久福利资源国产精品999| 青青草原综合久久大伊人| 伊人久久大香线蕉亚洲五月天| 亚洲AV无码久久| 日日躁夜夜躁狠狠久久AV| 2022年国产精品久久久久| 精品无码久久久久久久久久| 亚洲性久久久影院| 久久久久亚洲AV无码观看| 久久九九青青国产精品| 欧美色综合久久久久久| 亚洲狠狠婷婷综合久久久久| 91久久福利国产成人精品| 欧美激情一区二区久久久| 狠狠色丁香婷婷综合久久来| 欧美日韩中文字幕久久久不卡| 无码伊人66久久大杳蕉网站谷歌| 久久精品国产99国产电影网| 久久免费国产精品| 精品久久久无码21p发布| 久久97久久97精品免视看| 亚洲欧美成人综合久久久| 久久久久久av无码免费看大片| 久久亚洲AV成人无码软件| 精品久久久无码中文字幕天天| 久久精品国产亚洲AV影院| 99久久国产综合精品网成人影院 | 久久亚洲国产欧洲精品一| 久久人人爽人人人人爽AV| 久久精品国产一区二区三区不卡| 久久精品亚洲中文字幕无码麻豆| 午夜视频久久久久一区| 91精品国产91热久久久久福利| 国产精品女同久久久久电影院| 久久精品人人做人人爽电影|