编译器使用各种函数的规则:
- 具体化优先于常规模板,普通函数优先于具体化和常规模板。
- 如果希望使用函数模板,可以用空模板参数强制使用函数模板。
- 如果函数模板能产生更好的匹配,将优先于普通函数。
#include <iostream>
#include <cstring>
#include <algorithm>
using namespace std;
void Func(int a, int b)
{
cout << "调用了普通函数" << endl;
}
template <typename T>
void Func(T a, T b)
{
cout << "调用了函数模板" << endl;
}
template<>
void Func(int a, int b)
{
cout << "调用了函数模板的具体化" << endl;
}
int main()
{
// 调用普通函数
Func(1, 8);
// 尽管普通函数int也能接收char类型参数
// 但是函数模板与char更匹配,所以不会使用普通函数
Func('a', 'o');
// 使用空模板参数<>强制使用函数模板具体化,而不是使用普通函数
Func<>(7, 4);
return 0;
}
函数模板分文件编写
- 函数模板只是函数的描述,没有实体,创建函数模板的代码放在头文件中。
- 函数模板的具体化有实体,编译的原理和普通函数一样,所以,声明放在头文件中,定义放在源文件中。