如何将此std :: function传递给std :: async

时间:2019-08-15 13:21:01

标签: c++ std-function stdasync

我正在处理一段多线程代码,但似乎无法将std :: function对象传递给std :: async函数。我确定我做错了什么,但我不知道那会是什么。因此,我准备了这段代码,以便也许认识的人可以帮助我。

Test1演示此std :: function对象有效。
Test2包含我想要执行的操作;只有我将函数对象包装到lambda中。
Test3包含我不知道的示例。

std::function<void(AsyncFunctionExample&)> current_function;

void Test1() {
  current_function = &AsyncFunctionExample::Function1;
  while(current_function != nullptr)
    current_function(*this);
}

void Test2() {
  current_function = &AsyncFunctionExample::Function1;
  while(current_function != nullptr)
    const std::future<void> function_future = std::async([&](){current_function(*this);});
}

void Test3() {
  current_function = &AsyncFunctionExample::Function1;
  while(current_function != nullptr)
    const std::future<void> function_future = std::async(current_function, *this);
}

此示例的完整代码可以在here中找到。 Stackoverflow编辑器警告说,不允许我转储完整的代码文件,因此这就是我在此处将其简化为基本内容的原因。

我收到的编译器错误是:
没有匹配的函数可以调用'async(std :: function&,AsyncFunctionExample&)'      const std :: future function_future = std :: async(current_function,* this);

这对我没有太大帮助。它基本上向我说明,没有与我的呼叫匹配的签名。但是我无法从该错误中找出呼叫的哪一部分是错误的,并且我不知道如何更改它才能正常工作。

1 个答案:

答案 0 :(得分:3)

您无法通过std::async传递引用,因为它需要复制值。您可以使用std::ref来解决此问题:

const std::future<void> function_future = std::async(current_function, std::ref(*this));

或者将函数更改为:

std::function<void(AsyncFunctionExample*)> current_function;

然后,您可以直接传递this

const std::future<void> function_future = std::async(current_function, this);