使用std :: string的移动赋值运算符(在VC11中)需要什么?
我希望它会被自动使用,因为在任务完成后不再需要v.
在这种情况下是否需要std :: move?如果是这样,我不妨使用非C 11交换.
#include <string> struct user_t { void set_name(std::string v) { name_ = v; // swap(name_,v); // name_ = std::move(v); } std::string name_; }; int main() { user_t u; u.set_name("Olaf"); return 0; }
解决方法
I hoped it’d be used automatically as v isn’t needed after the assignment anymore. Is std::move required in this case?
必须为左值明确说明移动,除非它们是从函数返回(按值).
这可以防止意外移动的东西.记住:运动是一种破坏性行为;你不希望它发生.
而且,如果name_ = v的语义会很奇怪;根据这是否是函数的最后一行而改变.毕竟,这是完全合法的代码:
name_ = v; v[0] = 5; //Assuming v has at least one character.
为什么第一行有时会执行一次复制而另一次会移动?
If so,I might as well use the non-C++11 swap.
你可以随意做,但std :: move对于意图更明显.我们知道这意味着什么以及您正在做什么.