考虑以下代码段:
template <class T>
struct remove_pointer
{
};
template <class T>
struct remove_pointer<T*>
{
typedef T type;
};
template <typename T>
T
clone(const T& v)
{
return v;
}
template <typename T, typename U = typename remove_pointer<T>::type>
T
clone(const U& v)
{
return new U(v);
}
int main()
{
auto foo = clone<double>(42.0);
return 0;
}
此代码生成编译错误:
In function 'int main()':
30:34: error: call of overloaded 'clone(double)' is ambiguous
30:34: note: candidates are:
14:1: note: T clone(const T&) [with T = double]
22:1: note: T clone(const U&) [with T = double; U = double]
为什么编译器T=double, U=double
在第 22 行派生?我认为它只应该通过如果T
是指针类型。