草庐IT

move-constructor

全部标签

c++ - constexpr 移动构造函数是否有意义?

constexpr移动构造函数是否有意义?例如,考虑以下内容:#includeclassC{public:constexprC(std::arrayar):m_ar{ar}{}constexprC(C&&other):m_ar{std::move(other.m_ar)}{}private:std::arraym_ar;};intmain(){constexprCc1{{{1,2,3}}};constexprCc2{std::move(c1)};return0;}这不会编译,因为尽管在c1上调用了std::move,编译器推断它需要使用(隐式删除的)复制构造函数,而不是移动构造函数。我

c++ - 为什么 std::sort 构造对象?

这个问题在这里已经有了答案:std::sortdoesnotalwayscallstd::swap(3个答案)关闭5年前。我创建了以下类来理解std::sort的行为:classX{public:X(inti):i_(i){}X(X&&rhs)noexcept:i_(std::move(rhs.i_)){mc_++;}X&operator=(X&&rhs)noexcept{i_=std::move(rhs.i_);ao_++;return*this;}voidswap(X&rhs)noexcept{std::swap(i_,rhs.i_);sw_++;}friendbooloperat

c++ - 为什么 std::move() 在 C++ 中工作?

以下是代码片段:inti=0;int&&k=std::move(i);在c++primer中移动是templatetypenameremove_reference::type&&move(T&&t){returnstatic_cast::type&&>(t);}据我所知,这个std::move模板会推导出一个类似的函数int&&move(int&t){returnstatic_cast(t);}作为比较并详细说明我的问题,考虑这样一个例子:inttest(intk){k=66;returnk;}intk;inta=test(k);上面的代码将被编译为:inttemp;//thetemp

Learn to earn,Move星航计划第三期邀请你探索编程和区块链的乐趣

星航计划是一个Web3技术的公益计划,旨在引导更多的人加入开源社区,学习Move语言,了解Web3。本期星航计划由 MoveFunsDao 发起,由Sui官方基金会支持,汇集了Web3开发领域内的专业导师,帮助那些对区块链开发感兴趣但尚未入门的朋友们快速了解和应用Web3开发。训练营亮点💻课程学习免费提供丰富的Move语言学习资料清晰的学习路线和活跃的交流环境👊技术指导不定时即兴直播分享每日星航自习室一对一指导💰贡献激励学习路线中设立了多级的里程碑奖励最高奖励可达1000RMB毕业学员专属NFT证书💧资源支持协助开发者申请Grant的支持帮助开发者推荐工作机会如果你是:🧑‍🎓相关专业学生:具有

c++ - 为什么 Builder 模式比在正在创建的 Class 对象中带有参数的 Constructor 更好?

为什么我们不能在构造函数本身中执行不同的构建步骤。如果构建步骤采用参数,为什么不能将它们作为参数提供给构造函数并在构造函数中用于创建对象。据我所知,在Builder模式中,客户端要创建哪个特定对象;那么在正在创建的类的对象中使用构建器而不是带有参数的构造函数有什么优势? 最佳答案 哦!我得到它。我正在查看维基百科示例并意识到Builder为何有用。当客户端不知道将哪些参数传递给构造函数时,这很有用,因为它非常复杂,因此无法直接调用构造函数并获取对象。因此,他向ConcreteBuilders寻求帮助,他们知道将哪些参数传递给构造函数

c++ - 隐式声明的 move 操作不会回退到复制?

我读过N3291“12.8.(11/15/28)Copyingandmovingclassobjectsclass.copy]”是否更正了隐式声明的move构造函数对所有非静态数据成员进行元素级move(可能通过分别定义的T(T&&)如果无法move任何非静态数据成员,隐式move构造函数将被标记为已删除并且不会尝试复制作为“后备”?(是的,move是为内置类型定义的,但实际上是一个拷贝)。同样move赋值,使用元素各自的Toperator=(T&&)。例子:structCopyOnly{CopyOnly();CopyOnly(constCopyOnly&);};//declaring

c++ - Eigen 中的 move 语义

我有几个关于Eigen的问题:有谁知道近期是否有计划在Eigen中支持move语义?在Eigen3网页的TODO列表中找不到任何内容。现在我正在使用swap技巧来摆脱临时对象,比如MatrixXdfoo(){MatrixXdhuge_matrix(N,N);//sizeNxNwhereNisquitelarge//dosomethingherewithhuge_matrixreturnhuge_matrix;}MatrixXdA(N,N);A.swap(foo());我非常想用C++11风格编写上面的swap行A=foo();并且不必担心foo()返回的临时值。C++98/C++03编

c++ - 在同一个赋值表达式中使用 std::move(object) 和 object.method() 。

下面表达式的结果是否定义明确?这是什么?hash_map[object.key()]=std::move(object);我不确定std::move部分的效果是否会发生在object.key()部分之前或之后,因此我的问题。 最佳答案 它的定义很明确,因为这段代码中的第一个并不重要:您可以将其重写为以下等价物hash_map[object.key()]=static_cast(object);关于代码我们能说些什么:object.key()应该在分配给map之前执行std::move(object)应在分配给map之前执行然后将对m

c++ - std::move 与 std::forward

这似乎是已经提出的最相关的问题。Whatsthedifferencebetweenstd::moveandstd::forward但是每个答案都是不同的,适用的和说的东西也略有不同。所以我很困惑。我有以下情况。将项目复制到容器中Copy项是C++03,所以我非常理解。将项目构建到容器中Constructitemintocontainer我相信使用完美转发正确地通过两个函数将参数转发到emplaceBackInternal()中T的构造函数(如果我错了请指出)。将元素移入容器我的问题似乎是理解如何将元素移入容器。代码:templateclassContainer{std::size_tl

c++ - 移动构造函数和赋值运算符 : why no default for derived classes?

为什么没有为派生类创建默认移动构造函数或赋值运算符?证明我的意思;具有此设置代码:#includestructA{A(){}A(A&&){throw0;}A&operator=(A&&){throw0;}};structB:A{};以下任一行抛出:Ax(std::move(A());Ax;x=A();但以下都没有:Bx(std::move(B());Bx;x=B();以防万一,我使用GCC4.4进行了测试。编辑:后来使用GCC4.5进行的测试显示了相同的行为。 最佳答案 通读0xFCD中的12.8(12.8/17特别是移动构造函数)