与成员函数异步
async with member function
我有一个代码:
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?
相关文章:
- 某些 boost::asio 异步函数是否将处理程序连接到操作,以便处理程序被触发一次?
- 调用boost.asio的异步函数时,线程是什么时候创建的
- 如何处理异步函数中的异常UWP应用程序getFileFrompathAsync(path);
- 如何在 std::future 的向量中调用异步函数
- 如何保持异步函数中使用成员的shared_ptr对象的活动状态?
- 如何声明异步函数
- C++中的异步函数调用
- 异步函数产生不一致的结果
- Windows中的C++异步函数
- Qt 中的异步函数调用
- 如何避免在调用异步函数进行 lambda 回调时出现额外的副本
- 如何创建异步函数
- 异步函数出错
- 如何调用boost::asio异步函数
- 处理c++中的复合异步函数
- std::异步函数串行运行
- 自动删除发送给异步函数的容器/io_service
- 异步函数调用的参数生存期
- c++boost asio异步函数在dll中不起作用
- 无法理解异步函数的值,特别是来自库的值