一.规则总述:
-如果函数模板和普通函数都可以实现,优先调用普通函数
-可以通过空模板参数列表来强制调用函数模板
-函数模板也可以发生重载
-如果函数模板可以产生更好的匹配,优先调用函数模板
(1).如果函数模板和普通函数都可以实现,优先调用普通函数
#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;
}
运行结果
调用的普通函数
(2)可以通过空模板参数列表来强制调用函数模板
#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;
}
运行结果
调用的模板
(3)函数模板也可以发生重载
#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;
}
运行结果
调用重载的模板
调用重载的模板
(4)如果函数模板可以产生更好的匹配,优先调用函数模板
#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;
}
运行结果
调用的模板
解释:在这里,变量为字符型,普通函数传入字符型变量可以发生隐式转换,模板函数可以自动匹配参数类型但是,普通函数要发生类型转换,模板函数不需要,显然模板函数的调用要更适合,因此在这里的结果是调用了模板函数
二.总结:
既然提供了函数模板,最好就不要提供普通函数,否则容易出现二义性