与成员函数异步

async with member function

本文关键字:异步 函数 成员      更新时间:2023-10-16

我有一个代码:

class cabc{
public:
    void pr()
    {
        cout<<"abcdef";
    }
};
int main()
{
    cabc cap;
    auto f = async(cap.pr);
    f.get();
    return 0;
}

此代码不起作用。我知道同样的事情可以做使用:

auto f = async(&cabc::pr,cap);

这是有效的。但为什么第一种方法不起作用呢?

cap.pr是一个不完整的成员函数调用表达式。必须在它后面加上包含适当函数参数的圆括号,才能生成有效的C++表达式。

因此,不能将cap.pr传递给std::async或任何其他函数。

要将成员函数传递给std::async,您需要使用找到的语法:

auto f=std::async(&capc::pr,cap);

尽管在这种情况下,您需要注意cap对象是被复制的。你也可以使用

auto f=std::async(&capc::pr,&cap);

以仅将指针传递到CCD_ 6。

如果指向成员函数语法的指针不受欢迎,那么可以使用lambda:

auto f=std::async([&]{cap.pr();});

这并不完全相同:它不将成员函数指针和对象指针传递给std::async,而是传递一个包含对cap的引用的lambda对象,该对象直接调用其pr成员函数。然而,结果基本上是一样的。

查看async:的函数签名

template< class Function, class... Args>
std::future<typename std::result_of<Function(Args...)>::type>
    async( Function&& f, Args&&... args );

(来自cppreference)

应该清楚的是,首先,无论Function&&是什么,都不可能是cap.pr&cabc::pr都是那种类型的情况。

更确切地说,Function&&应该是对函数指针的右值引用。&cabc::pr只是指向成员函数的指针的语法,因为它是成员函数,所以指向对象本身的指针需要是第一个参数。如果cap.pr是一个C风格的函数指针,那么您的第一个示例可能会工作。

老实说,我不知道为什么第二个样本有效,因为您没有传递指向对象的指针。

类似的问题还有许多其他的答案。例如:在C++11中,如何在成员函数上使用std::async?