[英]Pass function with args and return value to another function
Is it possible to pass function with arguments like this:是否可以使用这样的参数传递函数:
int func(int num)
{
return num;
}
to this function:到这个功能:
template<class T>
auto addTask(T task) -> std::future<decltype(task())>
{
auto wrapper = std::make_shared<std::packaged_task<decltype(task()) ()>>(std::move(task));
{
std::unique_lock<std::mutex> lock(mEventMutex);
mTasks.emplace([=] {
(*wrapper)();
});
}
mEventVar.notify_one();
return wrapper->get_future();
}
I know how pass function without agrs like this:我知道如何在没有 ags 的情况下传递函数,如下所示:
void func()
{}
It will be just:它将只是:
addTask(func);
but can't find where to place args.但找不到放置参数的位置。 Is it possible?
是否可以?
You could use a lambda that calls the function:您可以使用调用该函数的lambda :
addTask([some_value]()
{
func(some_value);
});
Or rewrite addTask
to use template parameter packs for possible arguments:或者重写
addTask
以使用模板参数包作为可能的参数:
template<typename Func, typename ...Args>
auto addTask(Func task, Args... arguments) -> std::future<decltype(task(arguments...))>
{
auto wrapper = std::make_shared<std::packaged_task<decltype(task(arguments...)) (Args...)>>(std::move(task));
{
std::unique_lock<std::mutex> lock(mEventMutex);
mTasks.emplace([=] {
(*wrapper)(std::forward<Args>(arguments)...);
});
}
mEventVar.notify_one();
return wrapper->get_future();
}
addTask(func, some_value);
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.