Я просто обнаружил, что не полностью понимаю логику std::move()
.
Во-первых, я googled, но похоже, что есть только документы о том, как использовать std::move()
, а не как работает его структура.
Я имею в виду, я знаю, что такое функция члена шаблона, но когда я смотрю в определение std::move()
в VS2010, он все еще запутан.
определение std:: move() идет ниже.
template<class _Ty> inline
typename tr1::_Remove_reference<_Ty>::_Type&&
move(_Ty&& _Arg)
{ // forward _Arg as movable
return ((typename tr1::_Remove_reference<_Ty>::_Type&&)_Arg);
}
Что для меня странно, это параметр, (_Ty && _Arg), потому что, когда я вызываю функцию, как вы видите ниже,
// main()
Object obj1;
Object obj2 = std::move(obj1);
он в основном равен
// std::move()
_Ty&& _Arg = Obj1;
Но, как вы уже знаете, вы не можете напрямую связать LValue с ссылкой RValue, что заставляет меня думать, что это должно быть так.
_Ty&& _Arg = (Object&&)obj1;
Однако это абсурдно, потому что std:: move() должен работать для всех значений.
Итак, я догадываюсь, чтобы полностью понять, как это работает, я должен также взглянуть на эти структуры.
template<class _Ty>
struct _Remove_reference
{ // remove reference
typedef _Ty _Type;
};
template<class _Ty>
struct _Remove_reference<_Ty&>
{ // remove reference
typedef _Ty _Type;
};
template<class _Ty>
struct _Remove_reference<_Ty&&>
{ // remove rvalue reference
typedef _Ty _Type;
};
К сожалению, он все еще запутан, и я не понимаю.
Я знаю, что это все из-за отсутствия базовых синтаксических навыков в С++. Я хотел бы знать, как эти работы тщательно и любые документы, которые я могу получить в Интернете, будут более чем приветствуемыми. (Если вы можете просто объяснить это, это тоже будет потрясающе).