C++ future async promise 用法详解 - async

async

背景

  • C++11添加了thread,可以通过std::thread({})方便的创建线程
  • thread不能方便的获取线程运行结果

用法

  • 返回值为std::future(下面会讲到),第一个参数policy,第二个参数为function,可以是lamda

    template< class Function, class... Args >
    std::future<std::invoke_result_t<std::decay_t<Function>, std::decay_t<Args>...>>
        async( std::launch policy, Function&& f, Args&&... args);
    
  • 关于policy

    • std::launch::async 新建线程,异步执行
    • std::launch::deferred 当前线程,调用特定函数时,同步执行
    • std::launch::async | std::launch::deferred 取决于实现,不得而知
    • NULL 取决于实现,不得而知

detail

  • std::launch::async 理论上会新建线程异步执行task,std::launch::deferred 只会在当前线程执行

    int main() {
      	std::cout << std::this_thread::get_id() <<std::endl;
        std::vector<std::future<void>> futures;
        for (int i = 0; i < 25; ++i) {
            // 当policy为std::launch::deferred时,可以看到所有thread id都是主线程id
            // 当policy为std::launch::async时,可以看到所有thread id各不相同
            auto fut = std::async(std::launch::deferred, [] {          
                std::cout << std::this_thread::get_id() <<std::endl;
            });
            futures.push_back(std::move(fut));
        }
        std::for_each(futures.begin(), futures.end(), [](std::future<void> & fut) {
            fut.wait();
        });
    }
    
  • policy为async时,如果没有获取结果,会单线程同步执行task

    int main() {
      std::cout << std::this_thread::get_id() <<std::endl;
      // 会在主线程外新建一个线程,去同步顺序执行下面两个task,可以看到thread id相同
      std::async(std::launch::async, []() {
      // 如果上一行替换成 auto f = std::async(std::launch::async, []() {
      // 会新建两个线程,并行执行两个task
        std::cout << std::this_thread::get_id() <<std::endl;
      });
      std::async(std::launch::async, []() {
        std::cout << std::this_thread::get_id() <<std::endl;
      });
    }
    
  • 由于async采用async policy时,本质上还是新建一个线程

    所以不适合轻量task,线程的创建和销毁开销可能更大

    这里未来应该支持线程池

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值