尝试将参数包的第一个元素作为函数调用,并将包的其余部分作为参数传递给它
Trying to call the first element of a parameter pack as a function and pass the rest of the pack to it as arguments
我必须使用以下接口编写一个模板函数:
template <typename... Args>
void create(Args&&... args)
我需要能够这样称呼它:
create([](int, float){}, 42, 5.f);
我希望使用后面传递的 2 个参数调用函数 (lambda(。我怎样才能做到这一点?
我受到create()
接口的限制 - 我无法分离参数包的函数参数 ouf,因为...原因(相信我(。也许可以使用一些技巧提取它,例如在此处,并将参数包的其余部分转发给它......?
这应该适用于接受任意数量参数的函数 - 而不仅仅是 int 和浮点数。
一个简单的解决方案是要求执行没有签名限制的帮助程序函数。
通过示例
#include <iostream>
template <typename L, typename ... Args>
void create_helper (L const & l, Args && ... args)
{ (void)l(args...); }
template <typename ... Args>
void create (Args && ... args)
{ create_helper(args...); }
int main()
{
create([](int i, float f){ std::cout << i << ", " << f << std::endl; },
42, 5.f);
}
这应该适用于接受任意数量参数的函数 - 而不仅仅是 int 和浮点数。
在 C++14 中,您可以通过就地调用的通用 lambda 来解压缩它们,并将参数转发到该 lambda。
举一个最小的工作示例:
#include<utility>
template <typename... Args>
void create(Args&&... args) {
[](auto &&f, auto&&... p){
std::forward<decltype(f)>(f)(std::forward<decltype(p)>(p)...);
}(std::forward<Args>(args)...);
}
int main() {
create([](int, float){}, 42, 5.f);
}
在 C++11 中,您可以使用另一个函数模板或执行相同工作的等效函子,然后使用它们代替通用 lambda。
举一个最小的工作示例:
#include<utility>
struct Functor {
template<typename F, typename... Args>
static void invoke(F &&f, Args&&... args) {
std::forward<F>(f)(std::forward<Args>(args)...);
}
};
template <typename... Args>
void create(Args&&... args) {
Functor::invoke(std::forward<Args>(args)...);
}
int main() {
create([](int, float){}, 42, 5.f);
}
相关文章:
- 将数组作为参数传递给函数安全吗?作为第三方职能部门,可以探索他们想要的之外的其他元素
- 使用指向成员的指针将成员函数作为参数传递
- 如何将参数传递给正在使用模板的类
- 是否有C++编译器选项允许激进地删除所有函数调用,并将参数传递给具有空体的函数
- 修改函数中的指针(将另一个指针作为参数传递)
- 如何将部分流作为参数传递
- 我正在开发服务器,ip作为参数传递不起作用
- 将成员函数指针作为参数传递给模板方法
- 如何在C++中将迭代器作为函数参数传递
- 将附加参数传递给使用 beast::bind_front_handler 调用的函数
- 如何将一个类的函数作为另一个类的另一个函数的参数传递
- 将参数传递为"const"的奇怪效果
- 如何在 c++ 中将函数作为参数传递?
- 在 C++ 中将非指定类型作为参数传递的最佳方法?
- 使用引用与指针将数组作为参数传递
- 如何将成员函数作为回调参数传递给需要"typedef-ed"自由函数指针的函数?
- 将参数打包的参数传递到 std::queue 中,以便稍后使用不同的函数调用
- 为什么我不能将引用作为 std::async 的函数参数传递
- 如何在不使用指针的情况下将派生类的对象作为参数传递给基类中的函数?
- 将__device__ lambda 作为参数传递给 __global__ 函数