C++函数模板初学理解
前言
作为一名初学c++语言的新同学,分享一段刚接触函数模板的一份自我理解(结合教材)
定义:
所谓函数模板,本身为一种函数。即建立一个通用函数,其函数类型及参数类型不做指定,定义一个虚拟类型代替,这样的函数称为函数模板
函数模板的一般形式为
template<typename T>
或
template<class T>
即 typename 可用 class 代替
typename与class均表示 “类型名”
例:
template<typename T>
void fun(T a,T b)
或
template<class T>
T fun(T a,T b)
eg1:
将n个数据排序,数据类型可以为整型,单精度型,双精度型.
//函数模板
//将n个数据排序,数据类型可以为整型,单精度型,双精度型.
#include <iostream>
using namespace std;
template<typename T> //模板声明,T为类型参数
//函数模板,关键词 template typename
//(可以用 class 代替).
void sort(T a[],int m) //定义排序函数
//此处main函数里的实参类型取代T类型
{
int i, j;
T t;
for(i=0;i<m-1;i++) //冒泡排序法
for(j=0;j<m-1-i;j++)
if (a[j] > a[j + 1])
{
t = a[j];
a[j] = a[j + 1];
a[j + 1] = t;
}
for (i = 0; i < m; i++)
cout <<" "<< a[i];
cout << endl;
}
int main()
{
int s[100], i,n;
float t[100];
double r[100];
cout << "请输入比较个数:" << endl;
cin >> n;
for (i = 0; i < n; i++)
cin >> s[i];
for (i = 0; i < n; i++)
cin >> t[i];
for (i = 0; i < n; i++)
cin >> r[i];
sort(s, n);
sort(t, n);
sort(r, n);
return 0;
}
运行结果:
新手发稿,希望路过的大佬们多多指教!
编程路漫漫,黑白一念间。
/狗头