草庐IT

move_function_imp

全部标签

c++ - 在 C++11 中从 std::deque move 一个元素

我们知道std::deque::front()返回对双端队列第一个元素的引用。我想知道这段代码是否总是安全的://dequeoflambdasdeque>funs;//thenissomeotherplace://takealockm.lock();autof=move(funs.front());//movethefirstlambdainffuns.pop_front();//removetheelementfromdeque//nowthevalueisholdbyfm_.unlock();//unlocktheresorcef();//executef我已经使用gcc-4.9尝

c++ - 为什么 `T(const T&&)` 被称为 move 构造函数?

[C++11:12.8/3]:Anon-templateconstructorforclassXisamoveconstructorifitsfirstparameterisoftypeX&&,constX&&,volatileX&&,orconstvolatileX&&,andeithertherearenootherparametersorelseallotherparametershavedefaultarguments(8.3.6).[..]为什么采用const右值引用的构造函数被标准称为“move构造函数”?一定it'sself-evident那thisprohibitsmea

c++ - 无法从模板类调用通用 std::function 成员

编译以下代码时:#includetemplateclassClass{std::functionfunc;public:Class(conststd::function&arg):func(arg){}voidcallFunc(){func();}};voidf(constinti){}intmain(){Classa(std::bind(f,10));a.callFunc();return0;}VS2015编译器在第六行生成以下错误消息:errorC2064:termdoesnotevaluatetoafunctiontaking0arguments.现在,我相信这是因为编译器认为f

c++ - std::unique_ptr::release() 与 std::move()

我有一个表示运行时上下文并构建树的类,树根保存在unique_ptr中。构建树完成后,我想提取树。这是它的样子(不可运行,这不是调试问题):classContext{private:std::unique_ptrroot{newNode{}};public://imagineaconstructor,attributesandmethodstobuildatreestd::unique_ptrextractTree(){returnstd::move(this->root);}};所以我使用std::move()从Context实例中提取根节点。但是,除了使用std::move()之外

c++ - 创建具有有限参数的 std::function 类型

给定可调用函数的类型C,我想在编译时得到一个std::function;其中的类型:具有与函数相同的返回类型C参数类型是第一个N函数的参数类型C这意味着,对于给定的类型void(int,char,double)和给定的N,函数的类型是:N=1=>结果类型:std::functionN=2=>结果类型:std::functionN=3=>结果类型:std::functionN>3=>编译时错误例子:templateconstexprautoget(){return/*(magicallysomehow)*/std::function}templatestructS{usingfunc=d

c++ - std::move 是否与左值引用一起使用? std::move 如何在标准容器上工作?

#includestructA{inta[100];};voidfoo(constA&a){std::vectorvA;vA.push_back(std::move(a));//howdoesmovereallyhappen?}intmain(){Aa;foo(a);}上面的代码编译正常。现在到处都写着move避免复制。以下是我的查询:move在处理左值时真的有效吗[非]-const引用?即使有“右值引用”,对象复制时如何避免复制像上面一样插入标准容器中?例如voidfoo(A&&a){//supposeweinvokethisversionstd::vectorvA;vA.push_

c++ - "Expected ' (' for function-style cast or type construction"错误是什么意思?

我收到错误“Expected'('forfunction-stylecastortypeconstruction”,我已尽力在线研究此错误的含义,但无法找到导致此错误的任何文档错误。我在StackOverflow上发现的所有相关问题都修复了特定的代码片段,并且没有更笼统地解释导致错误的原因。这些包括Expected'('forfunction-stylecastortypeconstruction答案突出了代码的几个问题。究竟是哪个问题导致了错误尚不清楚。c++Xcodeexpected'('forfunction-stylecastortypeconstruction在主函数中定义函

c++ - 在调用过程中删除 std::function

在调用过程中销毁/删除std::function是否是未定义行为?classEvent{public:Event(std::functionf):func(std::move(f)){}~Event(){}std::functionfunc;};intmain(){std::vectorevents;autofunc=[&](){events.pop_back();std::cout 最佳答案 这未被[res.on.objects]p2定义:Ifanobjectofastandardlibrarytypeisaccessed,and

c++ - 比较 std::function<>

是否有可能以某种方式比较两个std::tr1::function对象?如果我有一个function的集合怎么办?对象并想添加和删除事件处理程序?添加是微不足道的,但要找到要删除的那个似乎是不可能的。 最佳答案 简单来说,做不到。std::function(在它的所有迭代中,包括boost::function和std::tr1::function)不支持运算符==。 关于c++-比较std::function,我们在StackOverflow上找到一个类似的问题:

C++ 右值引用和 move 语义

所以我昨天在youtube上观看了c++视频,发现了一个关于C++-11右值引用和move语义的视频。我想我从广义上理解了这个概念,但是今天当我和助教一起检查我的代码时,他问我为什么没有在下面的代码中给我们一个引用(比如std::pair&p)。在这种情况下,我根本没有考虑过,但当他问起时,我想起了视频中所说的“在C++-11中,你通常应该使用按值传递。”因此我的问题是:在下面的代码中,std::pairp像std::pair&p一样过得更好或不?是否会使用move语义,它会有所作为吗?IPAddressNameServer::lookup(constHostName&host)con