和java泛型类似
逻辑相同,类型不同
模板函数template<class T>
模板声明必须紧跟着函数,只能对一个函数起作用
编译器会对函数模板进行两次编译,在声明的地方对模板代码本身进行编译,在调用的地方对参数替换后的代码进行编译。
调用时
1.自动类型推导,必须有参数类型才可以推导(不能是两个不同类型来代替T),既不可以做隐式转换
2.显示指定类型
#define _CRT_SECURE_NO_WARNINGS
#include<iostream>
using namespace std;
template<class T> // T是通用类型,也可使用template<typename T>来声明
void mySwap(T &a, T &b)
{
T tmp = a;
a = b;
b = tmp;
}
void test()
{
int a = 10;
int b = 20;
char c1 = 'c';
// mySwapInt(a, b);
//1 自动类型推导,必须有参数类型才可以推导
//mySwap(a, c1); 推导不出来T,所以不能运行
mySwap(a, b);
cout << "a = " << a << endl;
cout << "b = " << b << endl;
//2 显示指定类型
mySwap<int>(a, b);
cout << "a = " << a << endl;
cout << "b = " << b << endl;
double c = 3.14;
double d = 1.1;
mySwap(c, d);
cout << "c = " << c << endl;
cout << "d = " << d << endl;
}
int main() {
test();
system("pause");
return EXIT_SUCCESS;
}
通过具体化自定义数据类型(模板重载),解决某些类型不能共用的问题.
具体化语法template<> 返回值