如何将模板参数包转换为多个指针参数为函数
How do I convert a template parameter pack into multiple pointer arguments to a function?
我想实现以下内容:
template <typename Functor, typename... Params>
void foo(
size_t n
/* magic goes here, producing function parameters p1, p2, etc. */
/* corresponding to the parameter pack. */
)
{
for(size_t i = 0; i < n; i ++) {
std::cout << Functor()(
/* pass p1[i], p2[i], etc. corresponding to the */
/* parameter pack. */
) << 'n';
}
}
因此,foo会扩展到以下内容:
void foo(
size_t n,
const int* __restrict__ p1,
const int* __restrict__ p2
)
{
for(size_t i = 0; i < n; i ++) {
std::cout << std::plus()(p1[i], p2[i]) << 'n';
}
}
我有一个模糊的直觉,我可能需要将标准库超越标准库,例如我刚刚开始研究的Fusion,Brigand或Hana之类的东西。但是 - 也许我错了,这比我想象的要简单。
注意:
- 我通过指针到const的元组的解决方案是可以接受的,尽管它是最佳的 - 因为我无法将
__restrict__
应用于他们(因为它不是真正的C ,我知道我知道)。实际上,它本身甚至很有趣,因为我可能能够用元组执行其他技巧。 - 我不介意函子服用单个指针,而不是多个单独的指针。
- 我正在使用NVCC GCC 5.4.1;该代码应为c 11'ish(即我可以作为CUDA代码编译的C 11的一部分)。
- 我将结果流到
std::cout
只是为了不给任何人,我的想法我没有用函数的返回值做任何事情,这似乎是示例代码中最直接的事情。
template<class Functor, class...Ts>
void foo( std::size_t n,
Ts const* __restrict__ ... ts
) {
for(size_t i = 0; i < n; i ++) {
std::cout << Functor{}( ts[i]...) << 'n';
}
}
好吧,这很容易。
实时示例。
相关文章:
- 将可变参数函数的参数封装在类实例中
- QML 使用带有参数C++函数
- 使用可变参数函数作为模板参数
- 如何在C++中伪造虚拟可变参数函数模板?
- 为什么可变参数函数不适用于模板
- C++ std::functional 中的可变参数函数模板
- 可变参数函数指针的定义对于VxWorks spyLib来说不清楚
- 使用可变参数函数覆盖具有不同函数签名的虚函数
- 考虑引用和常量的可变参数函数包装器
- 使用可变参数函数将整数和/或整数数组放入单个 int 数组中
- 在可变参数函数中转发特定范围的参数
- 通过引用传递参数;函数返回类型是否必须为 VOID?
- 使用带有一个参数函数的递归找到数字的平方
- 可变参数函数模板不能很好地使用 std::function 作为参数
- 多个可变参数函数的单个模板参数包?
- 参数数据类型未知的可变参数函数
- 可变参数函数参数包扩展
- 使用模板可变参数函数将多个参数传递给另一个函数
- 对可变参数函数的递归调用的链接器错误
- 通过像printf这样的可变参数函数传递一个带有常量字符*转换函数的类