实现一个通用的交换函数
void Swap(int& x,int& y);
void Swap1(double& x,double& y);
void Swap2(char& x,chaar& y);
可以使用函数重载实现,但有其自己的缺点:
- 代码复用率较低,有新类型的函数,就要增加其相对应的函数。
- 代码的可维护性比较低,一个出错可能其他重载的函数出错。
模板
泛型编程
编写与类型无关的通用代码,是代码复用的一种手段。模板是泛型编程的基础。
分类
- 函数模板
- 类模板
函数模板
概念
函数模板代表了一个函数家族,该函数模板与类型无关,在使用时被参数化,根据实参类型产生函数的特定类型版本。
格式
template<class T>
原理
模板是一个蓝图,他本身并不是函数,是编译器用使用方法产生特定具体类型函数的模具。所以模板就是将本来应该我们做的重复的事情交给了编译器。
函数模板的实例化
分类:
隐式实例化、显示实例化
隐式实例化:让编译器根据实参推演模板参数的实际类型
template<class T>
T add(const T&