草庐IT

perfect-forwarding

全部标签

c++ - 将可变参数模板参数转发给多个类成员

以下安全吗?不会std::string是moved在第一类成员初始化之后?打印出来没问题,但我不确定。templateclassTest{public:templateTest(Args&&...args):m_one(newT(std::forward(args)...)),m_two(newT(std::forward(args)...))//m_one;std::unique_ptrm_two;};classC{public:C(inta,intb,conststd::string&c):m_a(a),m_b(b),m_c(c){std::coutt(1,2,"3");}我想这没

c++ - 使用 std::function 或转发引用作为高阶函数的通用可调用对象输入参数?

我想知道编写一个以std::function作为输入参数的高阶函数的主要区别、优缺点。或转发引用,例如templatevoidhof(F&&fun);.显然,前者比后者更严格,因为它指定了输入可调用对象必须符合的函数类型。 最佳答案 std::function通常具有显着的运行时开销。通过template参数传递通用可调用对象可避免std::function的间接成本,并允许编译器积极优化。我在theendofthisarticle为lambda递归编写了一些简单的基准测试(Y组合器与std::function).std::func

c++ - 为什么转发引用需要 std::forward

这个问题在这里已经有了答案:Whatarethemainpurposesofstd::forwardandwhichproblemsdoesitsolve?(7个答案)关闭5年前。在这样的函数模板中templatevoidfoo(T&&x){bar(std::forward(x));}不是xfoo中的右值引用,如果foo用右值引用调用?如果使用左值引用调用foo,则无论如何都不需要强制转换,因为x也将是foo内部的左值引用.还有T将被推导为左值引用类型,因此std::forward不会改变x的类型.我使用boost::typeindex进行了测试使用和不使用std::forward时,

c++ - 无法将类型 'int&' 的非常量左值引用绑定(bind)到类型 'int' 的右值

以下代码编译失败:#includeusingnamespacestd;intadd2(constint&x){returnx+2;}templateTadd2T(T&&x){returnadd2(std::forward(x));}intmain(intargc,char**argv){intx=0;cout通过这条消息:main.cpp:Ininstantiationof'Tadd2T(T&&)[withT=int&]':main.cpp:26:20:requiredfromheremain.cpp:12:16:error:cannotbindnon-constlvaluerefer

c++ - 多次传递输入参数的完美转发

考虑以下函数accept采用T类型的“通用引用”并将其转发给parse()具有左值重载和右值重载的函数对象:templatevoidaccept(T&&arg){parse()(std::forward(arg),0);//copyormove,dependingonrvaluednessofarg}templateclassparse{//parsewillmodifyalocalcopyormoveofitsinputparametervoidoperator()(Tconst&arg,intn)const{/*optimizedforlvalues*/}voidoperator(

c++ - 完美转发和 std::tuple

考虑以下代码:#include#include#include//A.templatevoidf(constchar*msg,Args&&...args){std::coutvoidf(constchar*msg,std::tuple&&t){std::coutg()const{returnstd::make_tuple(2,4,12345);}};intmain(){f("First",2,5,12345);f("Second",std::make_tuple(2,5,12345));boothe_boo;f("Third",the_boo.g());f("Fourth",std::

c++ - list 和 forward_list 性能之间的区别?

与c++11一样,我们有两种类型的列表:std::listlst={1,2,3,4,5};std::forward_listflst={5,4,3,2,1};我们知道list是基于双向链表的,forward_list是基于单向链表的。我们应该如何决定使用哪一个?以上任何列表是否有任何性能优势? 最佳答案 Howshouldwedecidewhichonetoused?决定是否需要双向迭代。如果前向迭代足够好,请使用std::forward_list,除非您需要支持早于C++11的C++版本,后者可能只有std::list。Isthe

c++ - 右值引用和完美转发

我读过一些关于&&的论文,我只是好奇是否有:voidfnc_1(int&&p){//...}voidfnc(int&&r){fnc_1(r);//amIsupposeto/shouldI?callitlikeso:fnc_1(std::forward(r))}还是只传递'r'就足够了? 最佳答案 fnc_1(r)不会编译,因为r是一个左值,就像任何其他变量一样,无论类型如何。是的,没错,命名右值引用是左值,而不是右值。fnc_1(std::forward(r))也不会编译,因为std::forward专门设计为不推断其模板参数。要传

c++ - 在 C++ 中使用 std::forward

我遇到过一段代码,其中使用了std::forward。我在谷歌上搜索了很长时间,但无法理解它的真正目的和用途。我在stackoverflow上看到过类似的帖子,但还是不太清楚。有人可以用一个简单的例子来解释吗?PS:我已经经历过这个page,但仍然无法欣赏它的用途。请不要将此问题标记为重复,而是尝试帮助我。 最佳答案 如您链接的页面所示:Thisisahelperfunctiontoallowperfectforwardingofargumentstakenasrvaluereferencestodeducedtypes,prese

c++ - 为什么右值引用会被通用引用变成左值引用

我想当通用引用参数与右值引用参数匹配时,将返回右值引用参数。然而,我的测试表明右值引用被通用引用函数模板变成了左值引用。为什么会这样?#include#includeusingnamespacestd;templateTf1(T&&t){//::value::value::value::value::value::value在GCC和VC++2010中,都是这样的结果:f2is_lvaluereference:0f2is_rvaluereference:1f2is_reference:1is_lvaluereference:1is_rvaluereference:0is_referen