c++tricks——模板的全特化与偏特化

本文深入探讨了C++中模板特化的概念,包括全特化与偏特化,并通过实例展示了如何应用于类模板与函数模板中。

模板为什么要特化,因为编译器认为,对于特定的类型,如果你能对某一功能更好的实现,那么就该听你的。

模板分为类模板与函数模板,特化分为全特化与偏特化。全特化就是限定死模板实现的具体类型,偏特化就是如果这个模板有多个类型,那么只限定其中的一部分。

先看类模板:

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;

};

那么下面3句依次调用类模板、全特化与偏特化:

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;

}

*/  

至于为什么函数不能偏特化,似乎不是因为语言实现不了,而是因为偏特化的功能可以通过函数的重载完成。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值