move的声明
move(_Tp&& __t) noexcept
{ return static_cast<typename std::remove_reference<_Tp>::type&&>(__t); }所以std::move(foo)并不会对foo进行任何操作,而是为了声明其为右值,调用移动构造函数或者移动赋值函数,对foo的真正操作在这些函数里
往往在移动构造函数(或者移动赋值函数)里,会进行成员指针的赋值,并把参数的成员指针赋值为空
所以在函数外面看来,std::move(foo)的结果看起来像是把foo的内存偷走了,foo自己不剩,但实际move并没有这个功能,这个是自己定义的
本文深入解析了C++中std::move的功能与作用机制。通过示例说明std::move并非直接改变原有对象的状态,而是将其作为右值引用传递,从而允许调用移动构造函数或移动赋值函数。解释了在移动过程中,原始对象的成员指针如何被置空,造成外部观察到的“内存被偷走”的现象。
174

被折叠的 条评论
为什么被折叠?



