std::async和std::future
std::async
创建一个后台线程执行传递的任务,这个任务只要是callable object均可,然后返回一个std::future
。future储存一个多线程共享的状态,当调用future.get时会阻塞直到绑定的task执行完毕:
复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
#include <iostream> #include <future> void task() { for (int i = 0; i < 10; i++) { std::cout << "A"; } } int main() { std::future<void> result{ std::async(task) }; for (int i = 0; i < 10; i++) { std::cout << "B"; } result.get(); //强制阻塞main线程,直到task线程执行完毕 system("pause"); return 0; }
std::launch::async
上面task返回void,这个结果没用,我们只是单纯的想等待任务线程结束。
对这种需求还可以用更简单的方法:指定一个launch policy
复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
#include <iostream> #include <future> void task() { for (int i = 0; i < 10; i++) { std::cout << "A"; } } int main() { std::future<void> result{ std::async(std::launch::async,task) }; for (int i = 0; i < 10; i++) { std::cout << "B"; } system("pause"); return 0; }
在创建async的时候指定一个launch policy,连result.get都可以不用了,不过还是需要把async的返回值赋给result。如果不赋值async会和同步调用一样在这里阻塞直到调用完毕,相当于没用async。
总共有两种launch policy:
std::launch::async
当返回的future失效前会强制执行task,即不调用future.get也会保证task的执行std::launch::deferred
仅当调用future.get时才会执行task
如果创建async时不指定launch policy,他会默认std::launch::async|std::launch::deferred
,根据情况选一种执行
std::launch::deferred
再来试试std::launch::deferred
策略。
复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
#include <iostream> #include <future> void task() { for (int i = 0; i < 10; i++) { std::cout << "A"; } } int main() { std::future<void> result{ std::async(std::launch::deferred,task) }; for (int i = 0; i < 10; i++) { std::cout << "B"; } result.get(); system("pause"); return 0; }
程序输出BBBBBBBBBBAAAAAAAAAA,和我们说的一样,创建async的时候它并没有开启新线程执行任务,而是等到result.get的时候才执行
转载于:https://www.cnblogs.com/ysherlock/p/8970847.html
最后
以上就是拉长长颈鹿最近收集整理的关于C++并发高级接口:std::async和std::futurestd::async和std::future的全部内容,更多相关C++并发高级接口:std内容请搜索靠谱客的其他文章。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复