c++11 async

#include <chrono>
#include <future>
#include <iostream>
#include <string>
#include <thread>

std::string fetchDataFromDB(std::string recvData)
{
    std::this_thread::sleep_for(std::chrono::seconds(5));
    return "DB_" + recvData;
}

std::string fetchDataFromFile(std::string recvData)
{
    std::this_thread::sleep_for(std::chrono::seconds(5));
    return "File_" + recvData;
}

/**
 * lambda函数作为回调用std::async
 * std::future<std::string> result = std::async([](std::string recData) {
 *      std::this_thread::sleep_for(std::chrons::seconds(5));
 *      return "DB_" + recData;
 * });
 *
 *
 */

int async_main()
{
    {
        std::chrono::system_clock::time_point start    = std::chrono::system_clock::now();
        std::string                           dbData   = fetchDataFromDB("Data");
        std::string                           fileData = fetchDataFromFile("Data");
        auto                                  end      = std::chrono::system_clock::now();
        auto                                  diff     = std::chrono::duration_cast<std::chrono::seconds>(end - start).count();
        std::cout << "total time taken = " << diff << "s\n";
    }
    {
        std::chrono::system_clock::time_point start  = std::chrono::system_clock::now();
        std::future<std::string>              result = std::async(std::launch::async, fetchDataFromDB, "Data");
        //接受一个回调函数作为参数的函数模板,并可能异步执行他们
        /**
         * std::lanch::async 保证异步行为,即传递函数将在单独的线程中执行
         * std::lanch::deferred 当其他线程调用get来方位共享状态时,将调用非异步行为
         * std::lanch::async | std::lanch::deferred 默认行为,他可以异步运行或不运行,取决于系统的负载无法控制
         *
         * 自动创建一个线程(或者从内部线程池中挑选)和一个promise对象
         * 然后将std::promise 对象差U能动给线程函数,便返回std::future对象
         * 当我们传递参数的函数退出时,他的值将被设置在这个promise对象中,所以最终的返回值将在std::future对象中可用
         *
         */
        std::string fileData = fetchDataFromFile("Data");
        std::cout << result.get();
        auto end  = std::chrono::system_clock::now();
        auto diff = std::chrono::duration_cast<std::chrono::seconds>(end - start).count();
        std::cout << "total time taken = " << diff << "s\n";
    }
    {
        std::future<std::string> result = std::async(
            [](std::string recData) {
                std::this_thread::sleep_for(std::chrono::seconds(5));
                return "DB_" + recData;
            },
            "Hello");
        std::cout << result.get() << "\n";
    }
}

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值