草庐IT

btn-move-forward

全部标签

c++ - 在 map 中就地构建不可 move 的对象

我正在尝试在包含原子的映射中构造一个对象,因此它既不能复制也不能moveAFAICT。我的C++读物reference是mapemplace应该能够做到这一点。但是由于删除或不存在的构造函数,以下代码无法编译。使用make_pair没有帮助。#include#includeclassZ{std::atomici;};std::unordered_mapmap;voidtest(void){map.emplace(0,Z());//errormap[0]=Z();//error}这可能吗,如果不可能,为什么不呢?编辑:Linux上的编译器是gcc4.8.1 最

c++ - 类型转换和使用 std::move() 的区别?

我对刚刚添加到最新C++标准中的新函数std::move()有点好奇。看完一篇文章,发现函数的定义是namespacestd{templateinlinetypenameremove_reference::type&&move(T&&x){returnx;}}这似乎在调用std::move和使用转换之间没有任何区别。比如这里,classNPC{intm_number1;intm_number2;public:NPC():m_number1(1),m_number2(2){cout认为基本没有区别是对的吗?嗯,我非常确定我是对的,但也知道过于自信总是适得其反。提前致谢!

c++ - std::move(std::unique_ptr()) 组合是否有标准缩写?

我终于要将我的代码库迁移到C++11,这会产生更短更好的代码。但是我发现当我用一个新的指针调用函数时,它比以前长了很多:voidaddCallback(Callback*);//Takesownershipofcallback.//...addCallback(newCallback);//Clear.成为voidaddCallback(std::unique_ptr);//Nocommentneedednow!//...addCallback(std::move(std::unique_ptr(newCallback)));//bleh.提议的make_unique()模板函数只会在

c++ - 与 (N)RVO 一起有效使用 move 语义

假设我想实现一个函数,该函数应该处理一个对象并返回一个新的(可能已更改的)对象。我想在C+11中尽可能高效地执行此操作。环境如下:classObject{/*ImplementationofObject*/Object&makeChanges();};我想到的备选方案是://Firstalternative:Objectprocess1(Objectarg){returnarg.makeChanges();}//Secondalternative:Objectprocess2(Objectconst&arg){returnObject(arg).makeChanges();}Objec

c++ - std::move 与 std::auto_ptr 相比?

我可以用C++11中的“移动”(右值引用)做什么我不能用std::auto_ptr做什么?(据我了解,它们是一个想法的不同实现。)老问题又来了:std::auto_ptr是这么糟糕的组件吗? 最佳答案 C++98/03没有真正“可移动”类的概念。auto_ptr是一个具有transfer-on-copy-semantics的类,即当您制作拷贝时,原始内容会发生变化(注意带有非常量参数的复制构造函数!)。这是不好的。这样的类不能在标准容器中使用。由于新添加的右值引用概念,C++11引入了真正可移动类的概念。新的unique_ptr完全

Learn to Earn,Move星航计划第三期诚邀您探索编程和区块链的乐趣

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

c++ - std::vector::data() 是否通过 move 保留?

这个问题在这里已经有了答案:关闭9年前。PossibleDuplicate:Doesmovingavectorinvalidateiterators?考虑以下代码:std::vectorprepare(T*&data){std::vectorbuffer;//Fillinbuffer.data=buffer.data();returnbuffer;}...T*data;autovec=prepare(data);//line12是否有可能vec.data()!=data在第12行?同样,std::vectorbuffer;//...Fillinbuffer...T*data=buffe

c++ - 试图更好地理解 std::forward、std::move

我正在编写一个基本的类模板。它的参数有两种参数类型。该类(class)的想法是将一种类型作为constref接受。另一个是ref.该类的功能是转换类型A输入B正在创建的对象最终将成为b.我想要perfect-forwarding或movesemantics此类模板的有效部分。现在这是我当前的类,只有基本类型,但计划使用可变参数结构将其扩展到任何2种类型。#ifndefCONVERTER_H#defineCONVERTER_H#includetemplateclassConverter{private:Fromin_;Toout_;public://WouldlikeforFromint

c++ - std::move into static_pointer_cast:为什么 static_pointer_cast 没有右值引用重载?

假设我们有一个函数需要一个按值共享的指针。(在现实生活中的例子中,我通过右值引用获取它并将其转发给成员。)voidf(std::shared_ptrptr){...}但是我们只有一个指向基类的共享指针,所以我们使用static_pointer_cast:std::shared_ptrptr=std::make_shared();f(std::static_pointer_cast(ptr));第一个赋值(从临时构造ptr)是否触发了引用计数的原子递增和递减,或者共享指针是否被移动?(请注意,它正在向上转换。)在static_pointer_cast中有引用计数的原子增量。如果我们不再需

c++ - forward_list、set、list 等如何调用 std::allocator?

我注意到分配器只能分配T类型的对象并保留大小为n*sizeof(T)的内存块.std::list内部的链表节点然而,类型不一定是T类型的对象,它们的大小也不一定与T相同对象。那样的话,怎么可能std::list使用std::allocator分配内存? 最佳答案 这就是为什么rebindtype存在。它允许您创建一个类似的分配器,而不是分配其他东西(例如node)。基本上是这样的:std::allocatorint_alloc;std::allocator::rebind>node_alloc;//Perhapsmoreuseful