草庐IT

move_group

全部标签

c++ - 实现 move 构造函数如何影响返回值优化?

考虑以下代码片段:#include#includeclassA{public:A(){std::cout它用g++和clang++编译得很好,输出是A::A()A::~A()在这种情况下,RVO似乎开始发挥作用。请注意,没有调用move构造函数。但是,如果从上面的代码中删除那个未使用的move构造函数,那么片段会变成这样:#include#includeclassA{public:A(){std::coutclang++和g++都拒绝编译它,因为类A的复制构造函数被标记为已删除,所以似乎没有发生RVO。如何删除未使用的move构造函数会导致这种情况? 最佳答

c++ - lambda 函数不是 throw_move_assignable 吗?

clang-cl(4.0.0-trunk)似乎认为是,而vc2015(update3)认为不是。此实现是否已定义或标准是否规定了lambda函数应如何在术语或nothrow和moveassignable中实现?#include#includetemplatevoidtest_nothrow_move_assignable(T&&){std::cout::value 最佳答案 这是clang错误。来自[expr.prim.lambda]:Theclosuretypeassociatedwithalambda-expressionhas

c++ - 为什么 std::allocator 要求 propagate_on_container_move_assignment 为真?

根据当前标准(20.7.9),std::allocator有一个成员propagate_on_container_move_assignment设置为true_type:templateclassallocator{public:typedefsize_tsize_type;typedefptrdiff_tdifference_type;typedefT*pointer;typedefconstT*const_pointer;typedefT&reference;typedefconstT&const_reference;typedefTvalue_type;templatestruc

c++ - 从 boost multi_index 数组中 move 元素

假设我有可move且不可复制的对象,并且我有带有random_access索引的boost多索引数组。我需要将我的对象移出数组前端,但我找不到任何方法可以在documentation中给我右值/左值引用.我只能看到front()给我不断的引用和pop_front()删除元素,但不返回任何东西。那么有没有办法将元素移出boostmulti-index呢? 最佳答案 添加到@sehe的回答中,下面显示了在您的可move类型不可默认构造的情况下如何修改代码:已编辑:更改代码以正确处理*extracted的破坏。已编辑:添加了std::un

c++ - 编译器会在 setter 方法中自动应用 move 语义吗?

我想知道是否允许编译器在以下setter方法中自动使用wstring的move构造函数(无需显式调用std::move):voidSetString(std::wstringstr){m_str=str;//Willstrbemovedintom_strautomaticallyorisstd::move(str)needed?}从我读到的内容来看,似乎不允许编译器做出此决定,因为str是一个左值,但很明显,在这里使用move不会改变程序行为。除非move,是否会应用其他类型的复制省略? 最佳答案 [is]thecompiler[.

c++ - 为什么 list<unique_ptr> 中的 unique_ptr 的 std::move() 没有真正 move 它?

usingPtr=std::unique_ptr;Ptrf(boolarg){std::listlist;Ptrptr(newint(1));list.push_back(std::move(ptr));if(arg){Ptr&&obj1=std::move(list.front());//Here|obj1|and|list.front()|stillpointtothesamelocation!list.pop_front();returnstd::move(obj1);}else{Ptrobj2=std::move(list.front());list.pop_front();r

c++ - 为什么 move 语义和 RVO 都没有按预期工作?

我最近在我的方程求解器中偶然发现了一些奇怪的行为,这让我问自己是否真的了解move语义和RVO如何协同工作。有很多relatedquestions在这个论坛上,我也读过manygeneralexplanations对此。但我的问题似乎很具体,所以我希望有人能帮助我。涉及的结构总体上有点复杂,但至少可以分解为:structFoo{Bar*Elements;Foo(void):Elements(nullptr){cout现在让我们考虑以下短程序:intmain(){Fooa=Foo::Example();cout这些是我在运行这段代码之前的期望:Example方法实例化本地Foo对象,导致

c++ - 指向堆栈分配对象和 move 构造的指针

注意:这是对aquestion的完整改写我前一阵子发帖了。如果您发现它们是重复的,请关闭另一个。我的问题很普遍,但似乎可以根据具体的简单示例更容易地解释它。所以想象一下,我想模拟办公室的电力消耗。假设只有灯和暖气。classSimulation{public:Simulation(Timeconst&t,doublelightMaxPower,doubleheatingMaxPower):time(t),light(&time,lightMaxPower),heating(&time,heatingMaxPower){}private:Timetime;//Note:stack-all

c++ - 如何将 `std::vector` 成员变量 move 到方法的调用者?

请考虑以下代码classA{public:A(std::size_td):m_v(d)std::vectoroperator()(){returnm_v;}private:std::vectorm_v;};我想movem_v给operator()的来电者而不是复制它。我需要做什么?简单地写returnstd::move(m_v)并将返回类型更改为std::vector&&? 最佳答案 写returnstd::move(m_v)就够了。 关于c++-如何将`std::vector`成员变量

c++ - 为什么我需要在临时 dynamic_bitset 上调用 std::move?

我在这里讲一个冗长的背景故事,因为除了直接回答之外,我还想知道我导致这种情况的推理是否正确。我有一个接受dynamic_bitset的函数参数(来自Boost.dynamic_bitset)。说它看起来像这样。voidfoo(boost::dynamic_bitsetdb){//dostuff}碰巧它只被临时调用,从构造函数构建,如foo(boost::dynamic_bitset{5}.set())(使用5位位集调用所有位集)。我的位集只有少量的位(少于32)。所以起初,我想“我只是按值传递它;拷贝比指针小。”但后来我想“它是动态的,所以它必须在堆上分配空间。我想避免不必要的分配和释