Pas*_* T. 2 c++ templates decltype variadic-templates c++14
很抱歉问一个以前可能会问的问题,但我搜索了足够长的时间并没有找到答案。
我的问题是我想调用一个类型的模板函数,template <typename GenericLambda, typename... LambdaArgs>而不需要总是decltype(my_lambda)先写在模板参数中。
#include <functional>
#include <string>
template <typename GenericLambda, typename... LambdaArgs>
auto lambda_to_mem_fn() {
auto ptr = &GenericLambda::template operator() < LambdaArgs... > ;
auto as_mem_fn = std::mem_fn(ptr);
return as_mem_fn;
}
auto my_lambda = [](auto x, auto y) { return x + y; };
// imaginary function
template <????>
auto make_lambda_to_mem_fn(GenericLambda generic_lambda)
{
// Extract lambda args types and forward them to lambda_to_mem_fn
using GenericLambda = decltype(generic_lambda);
lambda_to_mem_fn<GenericLambda, LambdaArgs...>();
}
void test() {
// How to remove the need to write decltype(my_lambda) ?
auto as_mem_fn = lambda_to_mem_fn<decltype(my_lambda), int, int>;
// I would like to write:
auto as_mem_fn2 = make_lambda_to_mem_fn<int, int>(my_lambda);
}
Run Code Online (Sandbox Code Playgroud)
我需要一个可移植的解决方案(即适用于 gcc、clang 和 msvc)。
在这方面有一段时间以来我一直在挠头,希望得到一些帮助;-)
链接到编译器资源管理器片段:https : //godbolt.org/z/pFk09J
参数包(如果存在)必须是模板参数列表中的最后一个参数的限制仅适用于主类模板。如果类型可以推导或默认,它可以出现在参数包之后:
template <typename... LambdaArgs, typename GenericLambda>
auto make_lambda_to_mem_fn(GenericLambda generic_lambda)
{
return lambda_to_mem_fn<GenericLambda, LambdaArgs...>();
}
Run Code Online (Sandbox Code Playgroud)
任何模板参数都将被 消耗LambdaArgs,而GenericLambda将从参数表达式中推导出来。