C++11的future和promise、parkged_task使用

时间:2022-03-23 08:24:31

future 的介绍

A future is an object that can retrieve a value from some provider object or function, properly synchronizing this access if in different threads.

它可以从异步的对象或者函数任务中获取结果,它通常和std::async、promise、packaged_task相互调用。

future对象通常是在valid有效的情况下可以使用,默认的构造函数是valid是false的,所以在使用future时,需要对其对象进行初始化。

future的成员函数

C++11的future和promise、parkged_task使用

成员函数

future用法

future可以从多线程中获取到相关的结果或者是线程输出的结果。因为线程的输出结果不会马上输出(等待执行完成),所以future会有一个共享的状态用于判断当前future的状态。

future输出结果会有三种状态,类型是std::future_status,它们分别是

  • deferred:还没开始;
  • ready:已经完成;
  • timeout:执行超时.

其中future获取结果的方式有这几种:get、wait、wait_for。

1、get等待异步操作结束并返回结果;

2、wait只是等待异步操作完成;

3、wait_for是超时等待返回结果。

future和async使用的例子

  1. #include <iostream>
  2. #include <future>
  3. #include <unistd.h>
  4.  
  5. int main(int argc, char **argv) {
  6.  
  7. std::future_status f_status;
  8.  
  9. auto func = [](int b) -> int{
  10. std::cout << "async thread running...." << std::endl;
  11. for (int i = 0; i< b; i++) {
  12. ;
  13. }
  14. return b;
  15. };
  16. std::future<int> fut = std::async(std::launch::async, func, 888888888);
  17. std::cout << "main thread running ...." << std::endl;
  18. std::chrono::milliseconds span(100);
  19. //方法一,用于等待异步操作的数据
  20. while(1) {
  21. f_status = fut.wait_for(span);
  22. if (f_status == std::future_status::ready) {
  23. std::cout << "future_status::ready ";
  24. break;
  25. } else if(f_status == std::future_status::deferred) {
  26. std::cout << "future_status::deferred ";
  27. } else if(f_status == std::future_status::timeout) {
  28. std::cout << "future_status::timeout ";
  29. }
  30. std::cout << std::endl;
  31. std::cout << "................";
  32. std::cout << std::endl;
  33. //fut.wait(); //方法二,等待异步线程的数据
  34. }
  35. std::cout << "future result " << fut.get() << std::endl;
  36. return 0;

编译脚本

  1. cmake_minimum_required(VERSION 2.6)
  2. set(src ./async.cpp)
  3. set(exe "async")
  4. set(CMAKE_CXX_FLAGS -std=c++11)
  5. add_executable(${exe} ${src})
  6. target_link_libraries(${exe} -lpthread)

promise

std::promise为获取线程函数中的某个值提供便利,在线程函数中给外面传进来的promise赋值,当线程函数执行完成之后就可以通过promis获取该值了,值得注意的是取值是间接的通过promise内部提供的future来获取的。

promise 成员函数

C++11的future和promise、parkged_task使用

成员函数

它的基本用法:

  1. std::promise<int> pr;
  2. std::thread t([](std::promise<int>& p){ p.set_value_at_thread_exit(9); },std::ref(pr));
  3. std::future<int> f = pr.get_future();
  4. auto r = f.get();

parkaged_task

std::packaged_task

std::packaged_task它包装了一个可调用的目标(如function, lambda expression, bind expression, or another function object),以便异步调用,它和promise在某种程度上有点像,promise保存了一个共享状态的值,而packaged_task保存的是一 个函数。它的基本用法:

  1. std::packaged_task<int()> task([](){ return 7; });
  2. std::thread t1(std::ref(task));
  3. std::future<int> f1 = task.get_future();
  4. auto r1 = f1.get();

promise和packaged_task与std::future的关系

std::future提供了一个访问异步操作结果的机制,它和线程是一个级别的属于低层 次的对象,在它之上高一层的是std::packaged_task和std::promise,他们内部都有future以便访问异步操作结 果,std::packaged_task包装的是一个异步操作,而std::promise包装的是一个值,都是为了方便异步操作的,因为有时我需要获 取线程中的某个值,这时就用std::promise,而有时我需要获一个异步操作的返回值,这时就用std::packaged_task,说直白点就是promise获取的是执行过程中设置的值,而packaged_task获取的是结果。

参考部分:

http://www.cplusplus.com/reference/future/future/?kw=future

https://www.cnblogs.com/KunLunSu/p/8051542.html

到此这篇关于C++11的future和promise、parkged_task使用 的文章就介绍到这了,更多相关C++11 future promise parkged_task内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://www.jianshu.com/p/5651de84e457