一、定义
所谓函数模版实际上就是建立一个通用函数
函数定义时不指定具体的数据类型(使用虚拟类型代替)
函数被调用时编译器根据实参反推数据类型–类型的参数化
使用情况
当一系列函数中函数名相同、内部操作类似,可使用函数模版来省去定义不同类型函数之苦
二、代码
template<typename T>
template<class T> 早期写法。关键字与类的关键字同名。所以后期改用 typename 关键字
#include <iostream>
using namespace std;
//书写函数模版
template<typename T> void Sort(T tArray[],int len);
// T 表示虚拟的数据类型,只在函数内部有效。可用其他字符表示
//template<class T> //class版本比较老。typename是C++ 11之后推荐使用的
template<typename T> void Show(T tArray[],int len);
int main()
{
int iNums[] = {56,54,12,89,43};
float fNums[] = {78.0f, 5.7f, 42.8f, 99.1f};
double dNums[] = {78.9, 23.6, 77.8, 98.5, 33.3};
cout<<"int型数组排序前"<<endl;
Show(iNums,sizeof(iNums)/sizeof(int));
Sort(iNums,sizeof(iNums)/sizeof(int));
cout<<"int型数组排序后"<<endl;
Show(iNums,sizeof(iNums)/sizeof(int));
cout<<endl<<"float型数组排序前"<<endl;
Show(fNums,sizeof(fNums)/sizeof(float));
Sort(fNums,sizeof(fNums)/sizeof(float));
cout<<"float型数组排序后"<<endl;
Show(fNums,sizeof(fNums)/sizeof(float));
cout<<endl<<"double型数组排序前"<<endl;
Show(dNums,sizeof(dNums)/sizeof(double));
Sort(dNums,sizeof(dNums)/sizeof(double));
cout<<"double型数组排序后"<<endl;
Show(dNums,sizeof(dNums)/sizeof(double));
cout << "123Hello world!" << endl;
return 0;
}
//习惯性将模版头与函数声明分两行写
template<typename T>
void Sort(T tArray[],int len){
T temp;
for(int i = 0;i<len-1;i++){
for(int j =0;j<len-i-1;j++){
if(tArray[j]>tArray[j+1]){
temp = tArray[j];
tArray[j] = tArray[j+1];
tArray[j+1] = temp;
}
}
}
}
template<typename T>
void Show(T tArray[],int len){
for(int i=0;i<len;i++){
cout<<tArray[i]<<", ";
}
cout<<endl;
}
结果