一.规则总述:
-如果函数模板和普通函数都可以实现,优先调用普通函数
-可以通过空模板参数列表来强制调用函数模板
-函数模板也可以发生重载
-如果函数模板可以产生更好的匹配,优先调用函数模板
(1).如果函数模板和普通函数都可以实现,优先调用普通函数
cpp
#include<iostream>
using namespace std;
//普通函数
void Print(int a, int b)
{
cout << "调用的普通函数" << endl;
}
//函数模板
template <class T>
void Print(T a, T b)
{
cout << "调用的模板" << endl;
}
void test()
{
int a = 10, b = 20;
//如果函数模板和普通函数都可以实现,优先调用普通函数
Print(a, b);
}
int main()
{
test();
return 0;
}
运行结果
cpp
调用的普通函数
(2)可以通过空模板参数列表来强制调用函数模板
cpp
#include<iostream>
using namespace std;
void Print(int a, int b)
{
cout << "调用的普通函数" << endl;
}
template <class T>
void Print(T a, T b)
{
cout << "调用的模板" << endl;
}
void test()
{
int a = 10, b = 20;
//通过空模板参数列表,强制调用函数模板
Print<>(a, b);
}
int main()
{
test();
return 0;
}
运行结果
cpp
调用的模板
(3)函数模板也可以发生重载
cpp
#include<iostream>
using namespace std;
void Print(int a, int b)
{
cout << "调用的普通函数" << endl;
}
template <class T>
void Print(T a, T b)
{
cout << "调用的模板" << endl;
}
template <class T>
void Print(T a, T b, T c)
{
cout << "调用重载的模板" << endl;
}
void test()
{
int a = 10, b = 20, c = 30;
//函数模板也可以发生重载
Print(a, b, c);
Print<>(a, b, c);
}
int main()
{
test();
return 0;
}
运行结果
cpp
调用重载的模板
调用重载的模板
(4)如果函数模板可以产生更好的匹配,优先调用函数模板
cpp
#include<iostream>
using namespace std;
void Print(int a, int b)
{
cout << "调用的普通函数" << endl;
}
template <class T>
void Print(T a, T b)
{
cout << "调用的模板" << endl;
}
template <class T>
void Print(T a, T b, T c)
{
cout << "调用重载的模板" << endl;
}
void test()
{
char a = 'a';
char b = 'b';
//如果函数模板可以产生更好的匹配,优先调用函数模板
Print(a, b);
}
int main()
{
test();
return 0;
}
运行结果
cpp
调用的模板
解释:在这里,变量为字符型,普通函数传入字符型变量可以发生隐式转换,模板函数可以自动匹配参数类型但是,普通函数要发生类型转换,模板函数不需要,显然模板函数的调用要更适合,因此在这里的结果是调用了模板函数
二.总结:
既然提供了函数模板,最好就不要提供普通函数,否则容易出现二义性