继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

C++并发高级接口:std::async和std::future

慕仔4209126
关注TA
已关注
手记 304
粉丝 69
获赞 305

C++并发高级接口:std::async和std::future

文章出处:racaljk---原文地址

目录

std::async和std::future
  std::launch::async
  std::launch::deferred

std::async和std::future

std::async创建一个后台线程执行传递的任务,这个任务只要是callable object均可,然后返回一个std::future。future储存一个多线程共享的状态,当调用future.get时会阻塞直到绑定的task执行完毕:

#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

#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策略。

#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的时候才执行


打开App,阅读手记
0人推荐
发表评论
随时随地看视频慕课网APP