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

            積木

            No sub title

              C++博客 :: 首頁 :: 聯系 :: 聚合  :: 管理
              140 Posts :: 1 Stories :: 11 Comments :: 0 Trackbacks

            常用鏈接

            留言簿(1)

            我參與的團隊

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            原文轉載自:http://www.shnenglu.com/shenhuafeng/archive/2006/12/30/17041.html

            Partial Template Specialization
            顧名思義,模版偏特化就是對模版進行特化的意思。

            舉個例子:
            namespace SHFTest
            {
                template
            <
                        
            class PLA,
                        
            class PLB
                        
            >
                
            class PLClass
                
            {
                    
            //
                    
            // 一般實現
                    
            //
                public:
                    PLClass()
            {};
                    
            ~PLClass(){};
                    
            void FuncA()
                    
            {
                    }

                }
            ;

                typedef myPLA;
                typedef myPLB;

                
            //
                
            // 單參數特化實現,參數A
                
            //
                template<class PLA>
                
            class PLClass<PLA,myPLB>
                
            {
                    
            //
                    
            // 特化實現
                    
            //
                    PLClass(){};
                    
            ~PLClass(){};
                    
            void FuncA()
                    
            {
                    }

                }
            ;

                
            //
                
            // 單參數特化實現,參數B
                
            //
                template<class PLB>
                
            class PLClass<myPLA,PLB>
                
            {
                    
            //
                    
            // 特化實現
                    
            //
                    PLClass(){};
                    
            ~PLClass(){};
                    
            void FuncA()
                    
            {
                    }

                }
            ;

                
            //
                
            // 雙參數特化實現
                
            //
                template<>
                
            class PLClass<myPLA,myPLB>
                
            {
                    
            //
                    
            // 特化實現
                    
            //
                    PLClass(){};
                    
            ~PLClass(){};
                    
            void FuncA()
                    
            {
                    }

                }
            ;
            }

             第一段代碼是一個普通的template class,支持兩個模板參數。

            假如我對于某種對象,需要做特殊化的處理,這樣就要用到模版偏特化了:
            例如第二段代碼,第三段代碼,第四段代碼分別對參數A,參數B和兩個參數做了偏特化。

            編譯器會幫你的代碼自動匹配到最好的模板上面進行實例化。

            這個有點類似于函數的重載,但是和重載是不一樣的,根據《深入探索C++對象模型》中的描述,函數重載會在運行時發生,利用函數對象忠的vtable來實現的。而模版偏特化發生在編譯期間,由編譯器來自動匹配完成的。沒有運行時的開銷。

            注意幾點:
            你能對已經做過偏特化的class忠的成員函數做偏特化,而你想單獨對某個函數做偏特化這是不允許的。請看以下例子:
            這樣是被允許的:
            namespace SHFTest
            {
                template
            <
                        
            class PLA,
                        
            class PLB
                        
            >
                
            class PLClass
                
            {
                    
            //
                    
            // 一般實現
                    
            //
                public:
                    PLClass()
            {};
                    
            ~PLClass(){};
                    
            void FuncA(){};
                }
            ;

                typedef myPLA;
                typedef myPLB;

                
            //
                
            // 單參數特化實現,參數A
                
            //
                template<class PLA>
                
            class PLClass<PLA,myPLB>
                
            {
                    
            //
                    
            // 特化實現
                    
            //
                    PLClass(){};
                    
            ~PLClass(){};
                    
            void FuncA();
                }
            ;

                template
            <class PLA>
                
            void PLClass<PLA,myPLB>::FuncA()
                
            {

                }

            }
            而下面的這種情況是不允許的,編譯不過的:
            namespace SHFTest
            {
                template
            <
                        
            class PLA,
                        
            class PLB
                        
            >
                
            class PLClass
                
            {
                    
            //
                    
            // 一般實現
                    
            //
                public:
                    PLClass()
            {};
                    
            ~PLClass(){};
                    
            void FuncA();
                }
            ;

                typedef myPLA;
                typedef myPLB;

                template
            <class PLA>
                
            void PLClass<PLA,myPLB>::FuncA()
               
            {

                }

            }
            當然直接偏特化namespace級別的函數也是不被允許的。你可以對這些函數做重載。這就意味著你只能更改函數的參數列表而不能改變函數的返回類型等。
            請看以下代碼:
            template <class T, class U> T Fun(U obj); 
            //primary template
            template <class U> void Fun<void, U>(U obj); 
            //illegal partial specialization
            template <class T> T Fun (Window obj); 
            //legal (overloading)

            寫得不好,還請大家指正。
            posted on 2012-11-15 10:23 Jacc.Kim 閱讀(528) 評論(0)  編輯 收藏 引用 所屬分類: VC / C++
            伊人久久大香线蕉亚洲| 国产精品久久久久久久午夜片| 伊人色综合久久天天网| 狠狠色狠狠色综合久久| 久久久九九有精品国产| 欧美激情精品久久久久久久九九九| 人人狠狠综合88综合久久| 久久天天躁狠狠躁夜夜96流白浆 | 亚洲精品无码久久毛片| 看久久久久久a级毛片| 精品国产热久久久福利| 日日噜噜夜夜狠狠久久丁香五月| 久久精品国产亚洲一区二区三区| 午夜精品久久久久久久| 久久久久亚洲AV综合波多野结衣 | 婷婷久久综合九色综合九七| 三上悠亚久久精品| 久久午夜无码鲁丝片秋霞 | 天堂久久天堂AV色综合| 久久天天躁狠狠躁夜夜不卡| 久久精品草草草| 久久国产欧美日韩精品| 中文字幕无码精品亚洲资源网久久| 国产免费久久精品丫丫| 伊人久久大香线焦综合四虎 | 久久乐国产精品亚洲综合| 久久久久人妻一区精品性色av| 亚洲精品第一综合99久久| 久久精品国产亚洲精品| 国产精品伊人久久伊人电影| 久久国产精品99久久久久久老狼| 日韩精品久久久久久免费| 久久久SS麻豆欧美国产日韩| 欧美精品国产综合久久| 亚洲综合伊人久久综合| 久久亚洲精品国产精品| 2021少妇久久久久久久久久| 久久国产精品99久久久久久老狼| 99麻豆久久久国产精品免费| 久久99国产精品99久久| 久久av免费天堂小草播放|