以下代码使用std :: move,我认为这是被考虑的做法,但是它与cl it崩溃.
class C { int x;}unique_ptr<C> transform1(unique_ptr<C> p) { return transform2(move(p),p->x); // <--- Oops! Could access p after move construction takes place,compiler-dependant}unique_ptr<C> transform2(unique_ptr<C> p,int val) { p->x *= val; return p;}
是否有一个更强大的约定,而不是简单地确保您通过std :: move将所有权转移到下一个函数之前,从p获取所需的所有内容.在我看来,使用移动对象并访问它来为相同的函数调用提供参数可能是一个常见的错误.
解决方法 既然你没有真正需要在移动p之后才能访问p,那么在移动之前要先获取p-> x,然后使用它.例:
unique_ptr<C> transform1(unique_ptr<C> p) { int x = p->x; return transform2(move(p),x);}总结
以上是内存溢出为你收集整理的c – 如何正确转发unique_ptr?全部内容,希望文章能够帮你解决c – 如何正确转发unique_ptr?所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)