template 02 模板的调用规则和局限性

1 如果函数模板和普通函数都可以实现,优先调用普通函数
2 可以通过空模板参数列表来强制调用函数模板(template<>(参数)
3 函数模板也可以发生重载
4 如果函数模板可以产生更好的匹配,优先调用函数模板

模板并不是万能的

template<class T>
void f(T a,T b){
a=b;
}
上述代码中提供的赋值操作,如果传入的a和b是一个数组,就无法实现了。

再例如:
template<class T>
void f(T a, T b){

if(a>b)
.........
}
在上述代码中,如果T的数据类型是像Person这样的自定义数据类型,也无法正常运行
 因此C++为了解决这种问题,提供了模板的重载,可以为这些特定的类型提供具体化的模板


#include<iostream>
#include<string>
using namespace std;
//模板的局限性
//模板并不是万能的,有些特定数据类型,需要用具体化的方式做特殊实现
//对比两个数据是否相等的函数
class Person {
public:
    Person(string name, int age) {
        this->m_name = name;
        this->m_age = age;
    }
    string m_name;
    int m_age;
};
template<class T>
bool myCompare(T& a, T& b) {
    if (a == b) {
        return true;
    }
    else {
        return false;
    }
}
//利用具体化实现代码,具体化优先调用!优先调用!!!传的是Person就会优先调用具体化的template
template<>bool myCompare(Person& p1, Person& p2) {
    if (p1.m_name == p2.m_name && p1.m_age == p2.m_age) {
        return true;
    }
    else {
        return false;
    }
}
void test02() {

    Person p1("Tom", 10);
    Person p2("Tom", 10);
    //要比较p1是否等于p2,要么用运算符重载,要么就用模板具体化,重载很麻烦,所以用具体化
    bool ret=myCompare(p1, p2);
    if (ret) {
        cout << "xiangdeng!" << endl;
    }
    else {
        cout << "buxiangdeng!" << endl;
    }
}
int main() {

    test02();

    system("pause");
    return 0;
}

//总结
//利用具体化的模板,可以解决自定义类型的通用化.
//学习模板并不是为了写模板,而是STL能够运用系统提供的模板!
 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值