Различие между ссылками rvalue и ссылками на пересылку было достаточно ясно описано в этом примере Скоттом Мейерсом:
Widget&& var1 = someWidget; // here, "&&" means rvalue reference (1)
auto&& var2 = var1; // here, "&&" does not mean rvalue reference (2)
template<typename T>
void f(std::vector<T>&& param); // here, "&&" means rvalue reference (3)
template<typename T>
void f(T&& param); // here, "&&"does not mean rvalue reference (4)
По существу, различие происходит, когда мы имеем выводимый контекст, поэтому случай (3) явно утверждает, что мы имеем vector<...>&&
, тогда как T
в случае (4) следует вывести и (после применения правил сворачивания ссылок), классифицированных в терминах "категория стоимости".
Но что происходит с более сложным сопоставлением шаблонов? Возьмем следующий пример, например:
template <template <class...> class Tuple, class... Ts>
void f(Tuple<Ts...>&& arg)
{
}
Что означает &&
здесь?