
一、函數模板做函數參數
#include <iostream>
using namespace std;
template<typename T, typename T2>
void sortArray(T *a, T2 num)
{
T tmp ;
int i, j ;
for (i=0; i<num; i++)
{
for (j=i+1; j<num; j++)
{
if (a[i] < a[j])
{
tmp = a[i];
a[i] = a[j];
a[j] = tmp;
}
}
}
}
template<class T>
void pirntArray(T *a, int num)
{
int i = 0;
for (i=0; i<num; i++)
{
cout<<a[i]<<" ";
}
}
void main()
{
int num = 0;
char a[] = "ddadeeettttt";
num = strlen(a);
printf("排序之前\n");
pirntArray<char>(a, num);
sortArray<char, int>(a, num); //顯示類型調用 模板函數 <>
printf("排序之后\n");
pirntArray<char>(a, num);
cout<<"hello..."<<endl;
system("pause");
return ;
}
二、函數模板遇上函數重載
函數模板和普通函數區別結論:
1.函數模板不允許自動類型轉化
2.普通函數能夠進行自動類型轉換
函數模板和普通函數在一起,調用規則:
1 函數模板可以像普通函數一樣被重載
2 C++編譯器優先考慮普通函數
3 如果函數模板可以產生一個更好的匹配,那么選擇模板
4 可以通過空模板實參列表的語法限定編譯器只通過模板匹配
案例1:
#include <iostream>
using namespace std;
template <typename T>
void myswap(T &a, T &b)
{
T t;
t = a;
a = b;
b = t;
cout<<"myswap 模板函數do"<<endl;
}
void myswap(char &a, int &b)
{
int t;
t = a;
a = b;
b = t;
cout<<"myswap 普通函數do"<<endl;
}
void main()
{
char cData = 'a';
int iData = 2;
//myswap<int>(cData, iData); //結論 函數模板不提供隱式的數據類型轉換 必須是嚴格的匹配
myswap(cData, iData);
//myswap(iData, cData);
cout<<"hello..."<<endl;
system("pause");
return ;
}
案例2:
#include "iostream"
using namespace std;
int Max(int a, int b)
{
cout<<"int Max(int a, int b)"<<endl;
return a > b ? a : b;
}
template<typename T>
T Max(T a, T b)
{
cout<<"T Max(T a, T b)"<<endl;
return a > b ? a : b;
}
template<typename T>
T Max(T a, T b, T c)
{
cout<<"T Max(T a, T b, T c)"<<endl;
return Max(Max(a, b), c);
}
void main()
{
int a = 1;
int b = 2;
cout<<Max(a, b)<<endl; //當函數模板和普通函數都符合調用時,優先選擇普通函數
cout<<Max<>(a, b)<<endl; //若顯示使用函數模板,則使用<> 類型列表
cout<<Max(3.0, 4.0)<<endl; //如果 函數模板產生更好的匹配 使用函數模板
cout<<Max(5.0, 6.0, 7.0)<<endl; //重載
cout<<Max('a', 100)<<endl; //調用普通函數 可以隱式類型轉換
system("pause");
return ;
}
