目录
泛型编程
写代码时,我们喜欢编写复用率高的代码,这样可以减少很多重复的工作量,但有时仅因为类型的不同需要重新编写,因此有了泛型编程的概念。
泛型编程:编写与类型无关的通用代码,是代码复用的一种手段。模板是泛型编程的基础。
函数模板
函数模板代表了一个函数家族,该函数模板和类型无关,会根据实参类型产生函数的特定类型版本。
temple<typename T>
void Swap(T& left,T& right)
{
T temp = left;
left = right;
right = temp;
}
实例化
构造了模板,用就是实例化,就好像用剑模造剑。
实例化有两种,隐式实例化和显式实例化。
1. 隐式实例化:让编译器根据实参推演模板参数的实际类型
template<class T>//模板
T Add(const T& left, const T& right)
{
return left + right;
}
int main() //实例化(隐式)
{
int a1 = 10, a2 = 20;
double d1 = 10.0, d2 = 20.0;
Add(a1, a2);
Add(d1, d2);
return 0;
}
2. 显式实例化:在函数名后的<>中指定模板参数的实际类型
int main(void)
{
int a = 10;
double b = 20.0;
Add<int>(a, b);// 显式实例化
return 0;
}
类模板
template<class T>
class Vector//Vector是类名
{
//类内成员定义
};
类模板实例化与函数模板实例化不同,类模板实例化需要在类模板名字后跟<>,然后将实例化的类型放在<>中即可,类模板名字不是真正的类,而实例化的结果才是真正的类。
// Vector类名,Vector<int>才是类型
Vector<int> s1;
Vector<double> s2;