函数模板
1 template <typename T>
函数声明或定义
2 利用模板实现类型参数化
(1)自动推导 ——swap(a,b)
(2)显示指定类型——swap<int>(a,b)
3
普通函数和函数模板指定类型均可以发生隐式类型转换
隐式类型转换——字符类型转换为整数类型(ascll值)
4 空模板参数列表——print<>(a,b)
5 模板局限性时(对自定义类型),使用具体化版本,优先调用新版本函数
template<> bool compare(Person &p1, Person &p2)
{
}
利用具体化的模板,可以解决自定义类型的通用化
类模板函数的调用时机
普通类的函数在一开始的时候就可以创建
类模板中的成员函数在调用的时候才创建,因为一开始无法确定类型
类模板对象做函数参数
指定传入类型
void printperson(Person<string, int>&p)
{
}
类模板与继承
1 如果父类是类模板,子类需要指定父类中 T的数据类型
类模板成员函数类外实现
template<class T1,class T2>
Person<T1, T2>::Person(T1 name, T2 age)
{
this->m_name = name;
this->m_age = age;
}
1 加上作用域
2 加上参数模板的声明 template<class T1,class T2>
3 在作用域后加上模板参数列表 Person<T1, T2>
类模板分文件编写
将.h和.cpp中的内容写在一起,将后缀名改为.hpp文件
类模板与友元
1 全局函数类内实现:直接在类内声明友元即可,加上关键字friend即可(建议)
2 全局函数类外实现
(1)声明为函数模板,加上空参数列表
(2)将全局函数写在类的前面,需要让编译器知道全局函数的存在
(3)提前声明类
(4)在类的前面再声明参数列表 template