给定一个模板和一个更专业的重载:
template <typename T>
const T& some_func(const T& a, const T& b)
{
std::cout << "Called base template\n";
return (a < b) ? a : b;
}
template <typename T>
T* const& some_func(T* const& a, T* const& b)
{
std::cout << "Called T* overload\n";
return (*a < *b) ? a : b;
}
然后以下工作按预期工作:
int main()
{
std::cout << some_func(5.3, 6.2) << "\n";
double a = 1;
double b = 2;
double *p = &a;
double *q = &b;
const double *ret = some_func(p, q);
std::cout << *ret << "\n";
return 0;
}
采用第一次印刷Called base template
,第二次印刷Called T* overload
。如果我们将重载签名替换为:
template <typename T>
const T*& some_func(const T*& a, const T*& b)
然后第二个调用现在调用基本模板。鉴于这int const& x
等于const int& x
,我假设T* const&
等于是不正确的const T*&
吗?为什么第一个版本正确解析,而第二个版本没有?