标签:perfect-forwarding c c11 wrapper variadic-templates
在回答this question时,我编写了这个工作代码,包装函数在模板参数中传递:
template<typename Fn, Fn fn, typename... Args>
auto wrapper(Args... args)->decltype(fn(args...)){
return fn(args...);
}
#define WRAPPER(FUNC) wrapper<decltype(&FUNC), &FUNC>
用法示例(我使用此代码进行测试):
int min(int a, int b){
return (a<b)?a:b;
}
#include<iostream>
using std::cout;
int main(){
cout<<WRAPPER(min)(10, 20)<<'\n';
}
两个人告诉我使用完美转发.当我问到如何做到这一点时,他们中的一个重定向了我here.我读了问题,仔细阅读了最佳答案,并将包装改为:
#include<utility>
template<typename Fn, Fn fn, typename... Args>
auto wrapper(Args&&... args)->decltype(fn(std::forward<Args...>(args...))){
return fn(std::forward<Args...>(args...));
}
它编译,除非我尝试使用上面的示例代码检查它.我该如何修复代码?
http://rextester.com/YUIYI99787
解决方法:
你在return语句的错误位置有点.你要:
return fn(std::forward<Args>(args)...);
这将扩展到:
return fn(std::forward<T1>(t1), std::forward<T1>(t2), ...);
你写的内容会扩展到:
return fn(std::forward<T1,T2,...>(t1, t2, t3));
诀窍在于每次看到“……”时,都要想“它会复制它背后的东西”.这可能会变得棘手,因为有各种各样的方法可以构建“背后的东西”,包括能够进行交叉产品等.
标签:perfect-forwarding,c,c11,wrapper,variadic-templates 来源: https://codeday.me/bug/20190725/1529964.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。