函数模版(function template)
- 建立一个通用函数,其函数类型和形参类型不具体指定,用一个虚拟的类型来代表,这个通用函数就称为函数模版
- 形式: template< typename T >
类型参数T是一个虚拟的类型名,要等到函数调用时根据实参的类型来确定T是什么类型.
例:编一个程序,用同一个函数名对n个数据进行从大到小排序,数据类型可以是int,float,double型.用模版函数实现.
#include<iostream>
using namespace std;
template<typename T> //模板函数
T sort(T*a,int n){ //*a为数组起始地址指针,n为数组长度
for (int i = 0; i < n-1; i++){ //冒泡排序法
for (int j = 0; j < n-1; j++)
if (a[j] > a[j + 1]){
T temp = a[j];
a[j] = a[j + 1];
a[j + 1] = temp;
}
}
for (int i = 0; i < n; i++)cout << " \t" << a[i];//用制表符将输出格式化
cout << endl;
return 0;
}
int main(){
int n = 10;
int a[10] = { 8, 9, 5, 7, 6, 1, 3, 8, 4, 8 };
float b[10] = { 1.4, 456.3, 343.4, 16.2, 546, 412.5, 12.1 };
double c[10] = { 12.455, 135.5, 12.45, 156.5, 5465.2, 12.5, 124.1};
sort(a,n);
sort(b, n);
sort(c, n);
return 0;
}
输出: