是否可以使用std :: apply将可变参数函数应用于元组?
例如,以下代码适用于GCC 6.2.1:
void print_t(std::string i, std::string j) {
std::cout << i << " " << j << std::endl;
}
int main() {
std::tuple<std::string, std::string> t{"ab", "cd"};
std::experimental::apply(print_t, t);
return 0;
}
但是,如果我尝试应用可变参数函数:
template<typename T>
void vprint(T && t) {
std::cout << std::forward<T>(t) << std::endl;
}
template<typename T, typename ... Ts>
void vprint(T && t, Ts ... ts) {
std::cout << std::forward<T>(t) << " ";
vprint<Ts...>(std::forward<Ts>(ts)...);
}
int main() {
std::tuple<std::string, std::string> t{"fd", "ab"};
std::experimental::apply(vprint, t);
return 0;
}
编译器抱怨它不能推断出vprint的模板参数.好的,让我们明确地写出来:
std::experimental::apply(vprint<std::string, std::string>, t);
现在,编译器最终会出现一些模糊的错误,这些错误暴露了标准的库内部.
我在C 11中编写了自己的std :: apply实现,我理解为什么它不能推断出可变参数函数模板的参数.但是,理论上,std :: apply具有该扣除所需的所有信息.
可变功能的应用是否也是GCC6中尚未实现的功能?兼容C 17的编译器是否允许这样的应用程序?
如果没有,它们是否允许应用实例化的可变参数模板函数,如vprint< std :: string,std :: string>?
解决方法:
使用vprint< std :: string,std :: string>,您必须传递r值引用,所以
std::experimental::apply(vprint<std::string, std::string>, std::move(t));
更好的方法是使用仿函数(感谢通用lambda):
std::experimental::apply([](auto&&... args) {
vprint(std::forward<decltype(args)>(args)...);
},
t);
标签:c,c14,apply,c17,stdapply 来源: https://codeday.me/bug/20190823/1702490.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。