函数模板
语法规则:
template <typename T>
void mySwap(T &a,T &b){
T temp = a;
a=b;
b=temp;
}
//一个简单的函数模板就搭建好了,
//后面使用的时候可以通过自动类型推导(计算机自动计算类型)
int a,b;
mySwap(a,b);
//也可以自己指定类型,如下
mySwap<int>(a,b);
作用:提高函数复用性,将函数类型参数化
注意:自动类型推导必须推导出一致的数据类型T方可使用
模板必须确定T的类型才可以使用
template <class T>//和之前的一样
void mySwap(T &a,T &b){
T temp = a;
a=b;
b=temp;
}
普通函数与函数模板区别
普通函数调用发生自动类型转换 可以发生隐式类型转换
函数模板用自动类型转换,不可以发生隐式类型转换
函数模板用显示指定类型,可以发生隐式类型转换
普通函数与函数模板调用规则
1、如果普通函数和函数模板都可以实现,优先普通函数
2、可以通过空模板参数列表来强制调用函数模板
3、函数模板也可以发生重载
4、函数模板可以产生更好的匹配优先调用函数模板
void mySwap(int &a,int &b){
T temp = a;
a=b;
b=temp;
}
template <class T>//和之前的一样
void mySwap(T &a,T &b){
T temp = a;
a=b;
b=temp;
}
//空模板调用函数模板
mySwap<>(a,b)
//更好的匹配调用函数模板,可通过参数类型确定是否更好匹配
注:提供了函数模板则尽量别写普通函数
局限性:模板的通用性不是万能的
某些特定数据类型需要具体化方法实现
//对比两个数是否相等
class Person{
public:
Person(string name,int age){
this->m_name=name;
this->m_age =age;
}
private:
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<>bool myCompare(Person &a,Person &b){
if(a.m_name==b.m_name&&a.m_age==b.m_age){
return true;
}
else{
return false;
}
}
学习模板是为了在STL中运用系统提供的模板
利用具体化的模板,可解决自定义的类型通用化