是否可以展开可变参数(lambda)模板并将这些函数 return 值传递给另一个可变参数函数?
Is it possible to unfold a variadic (lambda) template and the pass those functions return value to another variadic function?
所以我想知道给定一个可变参数模板函数,如下所示:
template<typename...Fs>
parse(int x, Fs...funcs);
我们确保(通过 C++20 概念)可转换为 std::function<double(int)>
。我们可以将它展开到另一个函数参数中,比如传递给以下参数:
template<typename...Ts>
test(Ts...args);
我们再次确保所有 Ts
是并且必须能够转换 double
。
期待的是,假设a
、b
、c
都是lambda表达式,调用parse(12, a, b, c)
等同于调用test(a(12), b(12), c(12))
.
我试过的东西如下
template<typename...Fs>
parse(int x, Fs...func) {
return test(..., funcs(x));
}
但是没用。似乎大多数展开表达式示例都在表达式中放置了一个函数,所以这是否意味着展开表达式本身不能 return 作为参数列表。相反,也许它只能 return 作为单个值?
如果是这样,是否有任何解决方法,比如先将其构造成 (..., void(arr[i++]=args))
之类的数组,但我找不到将其扩展回参数包的方法。 (我想将参数扩展回参数包,因为我想重用我的库中的其他函数,而不是编写另一个将数组或初始化列表作为参数的函数。)
语法为:
template <typename... Fs>
auto parse(int x, Fs... func)
{
return test(funcs(x)...);
}
所以我想知道给定一个可变参数模板函数,如下所示:
template<typename...Fs>
parse(int x, Fs...funcs);
我们确保(通过 C++20 概念)可转换为 std::function<double(int)>
。我们可以将它展开到另一个函数参数中,比如传递给以下参数:
template<typename...Ts>
test(Ts...args);
我们再次确保所有 Ts
是并且必须能够转换 double
。
期待的是,假设a
、b
、c
都是lambda表达式,调用parse(12, a, b, c)
等同于调用test(a(12), b(12), c(12))
.
我试过的东西如下
template<typename...Fs>
parse(int x, Fs...func) {
return test(..., funcs(x));
}
但是没用。似乎大多数展开表达式示例都在表达式中放置了一个函数,所以这是否意味着展开表达式本身不能 return 作为参数列表。相反,也许它只能 return 作为单个值?
如果是这样,是否有任何解决方法,比如先将其构造成 (..., void(arr[i++]=args))
之类的数组,但我找不到将其扩展回参数包的方法。 (我想将参数扩展回参数包,因为我想重用我的库中的其他函数,而不是编写另一个将数组或初始化列表作为参数的函数。)
语法为:
template <typename... Fs>
auto parse(int x, Fs... func)
{
return test(funcs(x)...);
}