草庐IT

move_group

全部标签

c++ - 最佳C++ move 构造函数实现实践

我想了解move构造函数的实现。我们都知道如果我们需要在C++类中管理资源,我们需要实现五法则(C++编程)。微软给了我们一个例子:https://msdn.microsoft.com/en-us/library/dd293665.aspx这是一个更好的方法,它使用复制交换来避免代码重复:Dynamicallyallocatinganarrayofobjects//C++11A(A&&src)noexcept:mSize(0),mArray(NULL){//Canwewritesrc.swap(*this);//or(*this).swap(src);(*this)=std::move

c++ - sort() 是否自动使用 move 语义?

isocpp.org指出:move-basedstd::sort()andstd::set::insert()havebeenmeasuredtobe15timesfasterthancopybasedversions[...]ifyourtypehasamoveoperation,yougaintheperformancebenefitsautomaticallyfromthestandardalgorithms.这是否意味着如果您在没有move构造函数或move赋值运算符的用户定义类型上调用sort(),那么就没有使用move语义?换句话说,要获得C++11性能改进的诸多好处,您应

c++ - 同一对象的双 move 是从左向右复制吗?

我只是c++11中move操作的初学者,所以玩它。但是发现了一些我无法理解的东西。#includeusingnamespacestd;classA{public:A(){coutCORRECT!!coutCORRECT!!b=std::move(a);//idon'tknowmaybesillybutstillletsdoitWHYNOT!!!,couldbejustmistake??coutWRONG!!coutWRONG!!}我原以为b=std::move(a)操作会有所不同,因为我第二次在对象a上应用move,但它正在向左复制侧面对象b到右侧对象a,这部分我不明白。或者我在编程中

c++ - 制作一个 const unique_ptr 然后尝试从它 std::move 给出相同的错误,就好像您试图访问复制构造函数一样

当我们尝试复制unique_ptr(例如,将一个唯一指针分配给另一个)时,我注意到错误是ErrorC2280std::unique_ptr#includeintmain(){std::unique_ptra=std::make_unique(2);std::unique_ptrb=a;}没关系,因为unique_ptr没有定义复制构造函数。您不会从唯一指针进行复制以在它们之间move(转移指针的所有权)。有趣的是(好吧,也许不是),这段代码抛出了同样的错误。现在我知道它是无效的(我将第一个unique_ptr声明为不可变对象(immutable对象)),但错误消息暗示它正在尝试调用复制

c++ - 复制初始化: why move or copy constructor was not called even if copy-elision is turned off?

我的问题不同,因为我可能“知道”复制省略。我正在学习复制初始化。但是,以下代码让我感到困惑,因为我已经使用-fno-elide-contructors-O0选项关闭了复制省略。#includeusingnamespacestd;classtest{public:test(inta_,intb_):a{a_},b{b_}{}test(consttest&other){cout我首先使用命令构建:g++-std=c++11-fno-elide-constructors-O0main.cpp-omain得到如下结果:**showelideconstructors**moveconstruct

C++ 如何在不使用 winapi 的情况下 move 文件并将它们从一个磁盘复制到不同的磁盘?

必须是纯c++,我知道system("copyc:\\test.txtd:\\test.txt");但我认为这是系统功能,而不是c++解决方案,否则我会出错吗? 最佳答案 std::fstream怎么样?打开一个用于阅读,另一个用于写入,然后使用std::copy让标准库处理复制。像这样:voidcopy_file(conststd::string&from,conststd::string&to){std::ifstreamis(from,ios::in|ios::binary);std::ofstreamos(to,ios::o

C++:在字符串中 move 语义#append

我需要将一些字符串合并为一个,出于有效的原因,我想在这种情况下使用move语义(当然这些字符串将不再使用)。所以我尝试了#include#include#includeintmain(){std::stringhello("Hello,");std::stringworld("World!");hello.append(std::move(world));std::cout我以为它会输出Hello,World!##NOTHING##但它实际输出Hello,World!World!如果用operator+=替换append,结果是一样的。这样做的正确方法是什么?我在debian6.10上

c++ - 正确使用工厂类的标准 move

我想创建一个如下所示的工厂类,但我不确定这是使用std::move的正确方法。我不想使用太多的shared_ptr,因为在另一个shared_ptr中的shared_ptr真的很难看,有时还会让人困惑......选项1:classFoo{public:Foo(Foo&&f){...}}classFooFactory{public:staticFoo&&createFoo(...){Footemp(...);returnstd::move(temp);}}main(){Foof=FooFactory::createFoo(...);}选项2:classFooFactory{public:

c++ - 在递归数据结构中 move unique_ptr<T> 数组

尝试编译以下代码会导致以下编译错误:errorC2280:'std::unique_ptr>::unique_ptr(conststd::unique_ptr>&)':attemptingtoreferenceadeletedfunction我的理解是数组“m_children”应该是可move的,因为unique_ptr指向的类型定义了move构造函数。除非这是由类的递归性质或我忽略的某些move语义元素引起的错误?#include#include#includeclassOctreeNode{public:OctreeNode(){};OctreeNode(OctreeNode&&

c++ - 从自身内部替换 std::function(通过 move 赋值到 *this?)

是否可以用另一个std::function替换一个std::function?以下代码无法编译:#include#includeintmain(){std::functionfunc=[](){std::cout可以修改编译吗?现在的错误消息是:'this'wasnotcapturedforthislambdafunction-我完全理解。但是,我不知道如何捕获func的this指针。我想,它甚至不是lambda中的std::function吧?!如何做到这一点?背景:我想要实现的是:在给定std::function的第一次调用中,我想做一些初始化工作然后替换具有优化功能的原始功能。我