Возьмем функцию Y, которая перегружает:
void Y(int& lvalue)
{ cout << "lvalue!" << endl; }
void Y(int&& rvalue)
{ cout << "rvalue!" << endl; }
Теперь определим функцию шаблона, которая действует как std:: forward
template<class T>
void f(T&& x)
{
Y( static_cast<T&&>(x) ); // Using static_cast<T&&>(x) like in std::forward
}
Теперь посмотрите на main()
int main()
{
int i = 10;
f(i); // lvalue >> T = int&
f(10); // rvalue >> T = int&&
}
Как и ожидалось, выход
lvalue!
rvalue!
Теперь вернитесь к функции шаблона f()
и замените static_cast<T&&>(x)
на static_cast<T>(x)
. Посмотрим на выход:
lvalue!
rvalue!
То же самое! Зачем? Если они совпадают, то почему std::forward<>
возвращает листинг с x
на T&&
?