C++ 模板全特化和偏特化
- 模板分为类模板与函数模板,特化分为全特化与偏特化。全特化就是限定死模板实现的具体类型,偏特化就是如果这个模板有多个类型,那么只限定其中的一部分。模板特化的原因:模板并非对任何模板实参都合适、都能实例化,某些情况下,通用模板的定义对特定类型不合适,可能会编译失败,或者得不到正确的结果。因此,当不希望使用模板版本时,可以定义类或者函数模板的一个特例化版本。
- 模板的全特化和偏特化都是在语句定义的模板基础之上,不能单独存在
- 类模板可以全特化,也可以偏特化:
下面3句依次调用类模板、全特化与偏特化:template<typename T1, typename T2> class Test{ public: Test(T1 i,T2 j):a(i),b(j){cout<<"模板类"<<endl;} private: T1 a; T2 b; }; template<> class Test<int , char>{ public: Test(int i, char j):a(i),b(j){cout<<"全特化"<<endl;} private: int a; char b; }; template <typename T2> class Test<char, T2>{ public: Test(char i, T2 j):a(i),b(j){cout<<"偏特化"<<endl;} private: char a; T2 b; };
Test<double , double> t1(0.1,0.2); Test<int , char> t2(1,'A'); Test<char, bool> t3('A',true);
- 对于函数模板,却只有全特化,不能偏特化:
//模板函数 template<typename T1, typename T2> void fun(T1 a , T2 b){ cout<<"模板函数"<<endl; } //全特化 template<> void fun<int ,char >(int a, char b){ cout<<"全特化"<<endl; } //函数不存在偏特化:下面的代码是错误的 /* template<typename T2> void fun<char,T2>(char a, T2 b){ cout<<"偏特化"<<endl; } */