Maison >développement back-end >C++ >Comment `std::move()` réalise-t-il la conversion des lvalues en rvalues en C ?
Comment std::move transforme-t-il les expressions en valeurs R ?
std::move() facilite la conversion des expressions en valeurs R (à droite références de valeur) pour activer la sémantique de déplacement. Cependant, l'implémentation dans la bibliothèque standard MSVC peut prêter à confusion.
L'implémentation est la suivante :
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); }
Montrons comment cela fonctionne :
Object obj1; Object obj2 = std::move(obj1); // _Ty&& _Arg binds to obj1
Sur en appelant std::move(), le paramètre de référence _Arg se lie à la lvalue obj1. Cependant, étant donné que la liaison d'une référence rvalue à une lvalue n'est pas directement autorisée, on pourrait s'attendre à ce qu'une conversion en une référence rvalue, telle que (Object&&), soit requise.
Approfondir l'implémentation de std :: Remove_reference clarifie les choses :
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; };
Cette implémentation révèle que Remove_reference transforme T& en T, T&& en T et T&&& en T. Par conséquent, pour notre cas, où obj1 est une lvalue de type Object, la fonction résultante devient :
Object&& move(Object& arg) { return static_cast<Object&&>(arg); }
Pour élaborer davantage :
Object&& move(Object&& arg) { return static_cast<Object&&>(arg); }
Le cast en Object&& est nécessaire car les références rvalue nommées sont traitées comme des lvalues, tandis que la conversion implicite de lvalue en référence rvalue est interdite.
Object&& move(Object& && arg) { return static_cast<Object&&>(arg); }
Ici, les règles d'effondrement de référence de C 11 entrent en jeu et permettent l'expression Object& && doit être interprété comme Object&, une référence lvalue, qui peut en effet se lier à des lvalues. Ainsi, la fonction finale transforme son argument en référence rvalue et le renvoie.
En conclusion, std::move() utilise std::remove_reference pour permettre la transformation des lvalues et des rvalues en rvalues, facilitant ainsi le déplacement sémantique en C .
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!