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能够运用系统提供的模板!