我有 2 个重载函数 - 一个采用 L 值,另一个采用 R 值。目的是使函数可以像这样调用:
Obj obj;
foo(obj);
或者:
foo(Obj());
所以,我写了 2 个重载函数:
template <class T>
void foo(T& v)
{
/* ... function body code goes here ... */
}
template <class T>
void foo(T&& v)
{
foo(v);
}
int main()
{
foo(int(5));
}
R 值重载只需要委托给 L 值重载。我理解它的方式,一旦我进入函数体,任何使用v
都会给我一个 L 值引用,除非我特别使用std::move
or std::forward
。所以foo(v)
在 R 值重载中调用应该自动调用 L 值版本(而不是递归。)
但是,编译器抱怨歧义:
test.cpp: In function ‘void foo(T&&) [with T = int]’:
test.cpp:305:12: instantiated from here
test.cpp:299:2: error: call of overloaded ‘foo(int&)’ is ambiguous
我不明白为什么这是模棱两可的。在 R 值重载中的调用foo()
应该清楚地调用 L 值版本。那么为什么不编译呢?