正确地专门化函数模板的正确方法

时间:2014-09-07 09:18:42

标签: c++ templates

我对函数的显式模板特化的语法略感困惑。

我们说我有以下内容:

template<class T> 
void f(T t)
{}

我知道,对于明确的专业化,我需要提供template <>,否则我会超载。以下两个编译:

// (a)
template<> 
void f<int>(int t)
{}

//(b)
template<> 
void f(int t)
{}

但是,(a)和(b)之间有什么区别?

1 个答案:

答案 0 :(得分:5)

如上所述,两者都做同样的事情。模板参数推导用于计算显式专业化中T的类型。 &#34;有趣&#34;在重载函数模板时启动:

template<class T>         //#1
void f(T t)
{}

template<class T>         //#2
void f(T* t)
{}

template<> 
void f<int*>(int* t)      // specializes #1
{}

template<> 
void f(int* t)      // specializes #2, equivalent to void f<int>(int* t)
{}

真正的&#34;有趣&#34;更改订单时开始:

template<class T>         //#1
void f(T t)
{}

template<> 
void f(int* t)      // specializes #1, equivalent to void f<int*>(int* t)
{}

template<class T>         //#2
void f(T* t)
{}

在这种情况下,您会得到违反直觉的结果:

int *p;
f(p);              // calls #2, not explicitly specialized #1

这就是为什么通常更好地使用重载而不是函数模板的显式特化。