std::future是一个非常有用也很有意思的东西,简单说std::future提供了一种访问异步操作结果的机制。从字面意思来理解, 它表示未来,我觉得这个名字非常贴切,因为一个异步操作我们是不可能马上就获取操作结果的,只能在未来某个时候获取,但是我们可以以同步等待的方式来获取 结果,可以通过查询future的状态(future_status)来获取异步操作的结果。future_status有三种状态:
deferred:异步操作还没开始
ready:异步操作已经完成
timeout:异步操作超时
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17//查询future的状态 std::future_status status; do { status = future.wait_for(std::chrono::seconds(1)); if (status == std::future_status::deferred) { std::cout << "deferredn"; } else if (status == std::future_status::timeout) { std::cout << "timeoutn"; } else if (status == std::future_status::ready) { std::cout << "ready!n"; } } while (status != std::future_status::ready);
获取future结果有三种方式:get、wait、wait_for,其中get等待异步操作结束并返回结果,wait只是等待异步操作完成,没有返回值,wait_for是超时等待返回结果。
std::async
创建一个后台线程执行传递的任务,这个任务只要是callable object均可,然后返回一个std::future
。future储存一个多线程共享的状态,当调用future.get时会阻塞直到绑定的task执行完毕
比起直接使用std::thread 相比,std::async和std::future有以下优势:
1.std::async 返回的future对象,可以方便地等待callable对象执行完成并获取其返回值;
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23#include <iostream> #include <future> #include <chrono> bool is_prime(int x) { for (int i = 2; i < x; i++) { if (x%i == 0) return false; return true; } } int main() { std::future <bool> fut = std::async(is_prime, 4); std::cout << "wait,Checking"; std::chrono::milliseconds span(10); while (fut.wait_for(span) == std::future_status::timeout) std::cout << '.' << std::flush; bool x = fut.get(); std::cout << "4" << (x ? " is" : "is not") << " prime.n"; return 0; }
2.能从实现库的一些高级功能中获益,比如线程池等,并大大减少异常的产生。
函数async()用法很像thread,同样可以启动一个线程,但该函数返回的是一个future对象而非thread对象,因此它的侧重点在于计算结果而非过程。async()是可以获取线程计算的结果
最后
以上就是细心大白最近收集整理的关于C++11 std::async和std::future的全部内容,更多相关C++11内容请搜索靠谱客的其他文章。
发表评论 取消回复