c语言的模板偏特化是什么意思?
模板为什么要特化,因为编译器认为,对于特定的类型,如果你能对某一功能更好的实现,那么就该听你的。
模板分为类模板与函数模板,特化分为全特化与偏特化。全特化就是限定死模板实现的具体类型,偏特化就是如果这个模板有多个类型,那么只限定其中的一部分。
先看类模板:
[cpp]
template
class Test
{
public:
Test(T1 i,T2 j):a(i),b(j){cout<<"模板类"<<endl;}
private:
T1 a;
T2 b;
};
template
class Test
{
public:
Test(int i, char j):a(i),b(j){cout<<"全特化"<<endl;}
private:
int a;
char b;
};
template
class Test
{
public:
Test(char i, T2 j):a(i),b(j){cout<<"偏特化"<<endl;}
private:
char a;
T2 b;
};
[cpp] view plaincopyprint?template
class Test
{
public:
Test(T1 i,T2 j):a(i),b(j){cout<<"模板类"<<endl;}
private:
T1 a;
T2 b;
};
template
class Test
{
public:
Test(int i, char j):a(i),b(j){cout<<"全特化"<<endl;}
private:
int a;
char b;
};
template
class Test
{
public:
Test(char i, T2 j):a(i),b(j){cout<<"偏特化"<<endl;}
private:
char a;
T2 b;
};
template
class Test
{
public:
Test(T1 i,T2 j):a(i),b(j){cout<<"模板类"<<endl;}
private:
T1 a;
T2 b;
};
template
class Test
{
public:
Test(int i, char j):a(i),b(j){cout<<"全特化"<<endl;}
private:
int a;
char b;
};
template
class Test
{
public:
Test(char i, T2 j):a(i),b(j){cout<<"偏特化"<<endl;}
private:
char a;
T2 b;
};
那么下面3句依次调用类模板、全特化与偏特化:
[cpp] view plaincopyprint?Test t1(0.1,0.2);
Test t2(1,'A');
Test t3('A',true);
[cpp] view plaincopyprint?Test t1(0.1,0.2);
Test t2(1,'A');
Test t3('A',true);
Test t1(0.1,0.2);
Test t2(1,'A');
Test t3('A',true);
而对于函数模板,却只有全特化,不能偏特化:
[cpp] view plaincopyprint?//模板函数
template
void fun(T1 a , T2 b)
{
cout<<"模板函数"<<endl;
}
//全特化
template
void fun(int a, char b)
{
cout<<"全特化"<<endl;
}
//函数不存在偏特化:下面的代码是错误的
/*
template
void fun(char a, T2 b)
{
cout<<"偏特化"<<endl;
}
*/
[cpp] view plaincopyprint?//模板函数
template
void fun(T1 a , T2 b)
{
cout<<"模板函数"<<endl;
}
//全特化
template
void fun(int a, char b)
{
cout<<"全特化"<<endl;
}
//函数不存在偏特化:下面的代码是错误的
/*
template
void fun(char a, T2 b)
{
cout<<"偏特化"<<endl;
}
*/
//模板函数
template
void fun(T1 a , T2 b)
{
cout<<"模板函数"<<endl;
}
//全特化
template
void fun(int a, char b)
{
cout<<"全特化"<<endl;
}
//函数不存在偏特化:下面的代码是错误的
/*
template
void fun(char a, T2 b)
{
cout<<"偏特化"<<endl;
}
*/
至于为什么函数不能偏特化,似乎不是因为语言实现不了,而是因为偏特化的功能可以通过函数的重载完成。
#include
#include
#include
using namespace std;
template
int frequency(const T arr[],int size,const T &item)
{
int n=0;
for(int i=0;i<size;++i)
if(arr[i]==item)
++n;
return n;
}
template //这样特化上述函数模版
int frequency(const char * const arr[],int size,const char* const &item)
{
int n=0;
for(int i=0;i<size;++i)
if(0==strcmp(arr[i],item))
++n;
return n;
}
int main()
{
const char * arr_char[]={"wang","zhang","li","wang","li","zhang"};
const char * str = "wang"; //定义一个const char *变量来代表常量字符串
std::cout<<frequency(arr_char,6, str)<<std::endl; //调用特化的模版,
}
你可以在函数模版和特化版本里添加cout来看调用哪个。现在调用的是特化版,你可以把它注释掉,就会调用模版了。
以上回答你满意么?
就是不是一般规格的函数,你需要在特殊的库函数里去创建