创建一个异步任务

假设我们想在子线程中返回一个值给父线程,除了使用引用传参外,还有什么别的方法吗?

当我们不着急获取一个计算的结果时,可以使用 std::async 来启动一个异步任务,让异步任务执行这个计算。计算结束后,std::async 会返回一个 std::future 对象,它保存着计算的结果,调用 get() 方法即可获取。
3.3 async和future
在上面的异步任务中,我们让线程休眠了3秒,此时主线程将阻塞在 get 方法上(因为还没算出来),直到我们的异步任务完成(3秒过去了),get 方法返回计算结果。

  • get() 方法只能调用一次
  • 如果不需要拿到计算结果,可以调用 wait() 方法

所以,在使用 future 对象调用 get 方法之前,主线程可以先去干别的事情,等到需要这个结果了,再去看异步任务是否执行完了即可。


向异步任务传递参数

当异步任务是一个类的成员函数时,std::async 有两种方式创建。

  • 第一个参数是指向成员函数的指针
  • 第二个参数是提供这个成员函数的类的对象(如果取地址,那么是引用传递;否则创建副本,值传递)
  • 后面的参数作为该成员函数的参数

下面的例子可以看到,主线程中 t1 的值已被更改。
3.3 async和future
当第二个参数是值传递时,主线程中的对象将不会被更改。
3.3 async和future
值得注意的是,std::ref、std::move 依然可以作为引用传递使用
3.3 async和future
仿函数,同样可以使用:
3.3 async和future


std::launch

这是一个枚举类型,主要有:

1)std::launch::deferred :表明函数调用被延迟到 wait() 或 get() 函数调用时才执行
3.3 async和future
惊奇地发现调用这个函数的线程和主线程的 ID 居然是一致的,这就说明是主线程调用的这个函数,并没有创建出新的线程。

2)std::launch::async:表示在新线程上执行,而且是不需要等到调用 get 或者 wait 方法的
3.3 async和future

相关文章:

  • 2021-10-04
  • 2021-09-26
  • 2022-12-23
  • 2021-08-21
  • 2021-11-19
  • 2022-12-23
  • 2021-05-21
  • 2021-09-13
猜你喜欢
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2021-10-09
  • 2022-12-23
  • 2021-11-05
  • 2022-12-23
相关资源
相似解决方案