c++11多线程 async、future、packaged_task、promise 第九讲

2023-05-16


(1)std::async、std::future创建后台任务并返回
(2)std::packaged_task
(3)std::promise
(4)小结
一、std::async、std::future创建后台任务并返回
希望线程返回一个结果;
std::async是一个函数模板,用来启动一个异步任务,启动起来一个异步任务后,
他返回一个std::future对象,std::future是一个类模板
什么事是启动一个异步任务呀?
就是自动创建一个线程,并开始执行对应的线程入口函数,它返回一个
std::future对象,这个对象中含有线程函数返回的结果(线程返回的结果)。
可以通过std::future对象的成员函数get()来获取结果。
std::future提供了一种访问异步操作结果的机制,这个结果没办法马上获得,
但是在这个线程执行完的时候,就可以获取到结果了,future对象里保存一个值,就是这个结果、

#include <future>
#include <list>
#include <map>
#include <mutex>
#include <thread>

int thread_fun()//线程入口函数
{
    cout<<"thread_fun start thread_id = "<<std::this_thread::get_id()<<endl;
    std::chrono::milliseconds dura(5000);//休息5秒
    std::this_thread::sleep_for(dura);//休息一定时长
    cout<<"thread_fun end thread_id = "<<std::this_thread::get_id()<<endl;
    
    return 5;
}

int main()
{
    //下列程序std::future对象get()成员函数等待线程执行结果并返回结果
    cout<<"main thread_id = "<<std::this_thread::get_id()<<endl;
    std::future<int> result = std::async(thread_fun);//创建一个线程,并开始执行
    绑定关系,流程不会卡在这里
    cout<<"continue..."<<endl;
    int def = 0;

    cout<<result.get()<<endl;//会先卡在get()这里,一直等到thread_fun执行完成,获取到返回值,然后线程程序才会继续向下。
    
    //result.wait();//等待线程返回,本身不返回结果;
    cout<<"end  ..."<<endl;
    return 0;
    
}


class B
{
public:
    int thread_fun(int my_mun)//线程入口函数
    {
        cout<<my_mun<<endl;
        cout<<"thread_fun start thread_id = "<<std::this_thread::get_id()<<endl;
        std::chrono::milliseconds dura(5000);//休息5秒
        std::this_thread::sleep_for(dura);//休息一定时长
        cout<<"thread_fun end thread_id = "<<std::this_thread::get_id()<<endl;
        
        return 5;
    }
}


int main()
{
    A a1;
    int mun=12;
    //下列程序std::future对象get()成员函数等待线程执行结果并返回结果
    cout<<"main thread_id = "<<std::this_thread::get_id()<<endl;
    std::future<int> result = std::async(&A::thread_fun,&a,num);//创建一个线程,并开始执行
    绑定关系,流程不会卡在这里
    cout<<"continue..."<<endl;
    int def = 0;

    cout<<result.get()<<endl;//会先卡在get()这里,一直等到thread_fun执行完成,获取到返回值,然后线程程序才会继续向下。
    
    //result.wait();//等待线程返回,本身不返回结果;
    cout<<"end  ..."<<endl;
    return 0;
    
}
 

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

c++11多线程 async、future、packaged_task、promise 第九讲 的相关文章

随机推荐

  • 用类对象(可调用对象)创建线程的手法(学习)

    其他创建线程的手法 xff1a 用类对象 可调用对象 就会执行operator这个函数 这样的程序每次执行结果都不一样 线程中使用了主线程的局不变量 xff0c 主线程执行结束后 xff0c i内存被回收 子线程还在使用i的引用 xff0c
  • c++11多线程编程

    https blog csdn net weixin 36049506 article details 93333549 https m nowcoder com tutorial 10003 e8e83f384e804a6cb285e4e
  • 从RealsenseD435 摄像头获取点云数据并滤波后在ROS中通过rviz显示

    从RealsenseD435 摄像头获取点云数据并滤波后在ROS中通过rviz显示 以体素滤波为例 参考以下博客 xff1a https blog csdn net jack20030552 article details 80269486
  • ubuntu系统下载的太慢,然后下载失败了

    最近ubuntu系统坏了 xff0c 想网上下载一个 xff0c 但是下载速度真的比蜗牛还慢啊 xff01 不能忍 xff01 show 出你的资源 xff1a 下载资源 xff0c 这些网站下载速度能到2M左右 xff0c 还是比之前的1
  • scp命令

    1 ssh p 22 username 64 ip 远程登录 ssh p 22 username 64 172 16 140 1 2 把本地当前目录下的01 py文件 复制到 远程家目录下 的桌面01 py scp P port 01 py
  • Ubuntu报错,无法获取锁 E: Could not get lock /var/lib/dpkg/lock-frontend - open (11: Resource temporarily...

    解决方法 最后使用了最暴力的解决办法 xff0c 直接删除这个锁的文件 xff1a sudo rm var lib dpkg lock frontend sudo rm var lib dpkg lock Ubuntu报错 xff0c 无法
  • 5 个越早知道越好的 Python 特性

    https mbd baidu com newspage data landingsuper context 61 7B 22nid 22 3A 22news 9039746731433820646 22 7D amp n type 61
  • 使用if语句处理列表(python从入门到精通课后习题)

    79 80页课后习题 5 8 以特殊方式跟管理员打招呼 xff1a 创建一个至少包含 5 个用户名的列表 xff0c 且其中一 个用户名为 39 admin 39 想象你要编写代码 xff0c 在每位用户登录网站后都打印一条问候消息 遍历用
  • 拷贝来一篇鸡血,且干了这杯酒~~真香

    1 技术的提升仅是量的积累 xff0c 思想的提升才是质的飞跃 xff01 老男孩 2 智慧源于多角度视野 xff0c 能力在于有多种选择 老男孩 3 基础不牢 xff0c 地动山摇 xff01 老男孩 4 相信可能你就无限接近可能 xff
  • C++11和c++14 新特性

    https www jianshu com p b8a36ff7ac27 1 nullptr nullptr 出现的目的是为了替代 NULL 传统 C 43 43 会把 NULL 0 视为同一种东西 nullptr 关键字 xff0c 专门
  • c++11并发与多线程(第一讲)

    一 xff1a 并发 进程的基本概念 并发 xff0c 线程进程要求必须掌握 1 1 并发 两个或者更多任务 xff08 独立的活动 xff09 同时发生 xff08 进行 xff09 xff1a 一个程序同时执行多个独立的任务 以前计算机
  • c++11并发与多线程(第二讲)

    范例演示线程运行的开始和结束 程序运行起来 xff0c 生成一个进程 xff0c 该进程所属的主线程开始自动运行 xff1b 实际上是主线程执行 xff0c 主线程从mian函数开始执行 xff0c 函数返回则线程执行结束 include
  • c++11多线程编程(第三讲)

    include lt iostream gt include lt thread gt include lt string gt using namespace std 自己创建一个线程 xff0c 也需要从一个函数开始运行 xff1b v
  • Prometheus 到底 NB 在哪里?- 每天5分钟玩转 Docker 容器技术(84)

    本节讨论 Prometheus 的核心 xff0c 多维数据模型 我们先来看一个例子 比如要监控容器 span style background color rgb 216 216 216 webapp1 span 的内存使用情况 xff0
  • 解读人生的四种汉堡模型

    解读人生的四种汉堡模型 自然界给了每一个人幸福的机会 xff0c 人们都知道 xff0c 却不知如何得到它 克劳狄 年度最重要的壁球赛就要临近了 我每天的训练已经极度艰苦 xff0c 同时还要严格控制饮食 尽管我的饮食习惯已经相当健康 xf
  • 进程间通信———共享内存的原理

    这篇写的不错给出链接 https blog csdn net ljianhui article details 10253345 下图是两个进程间使用共享内存通信的示意图 xff1a 进程A和进程B在操作系统os中都有自己的虚拟内存空间 这
  • linux进程间通信-共享内存

    linux进程间通信 共享内存 一 共享内存介绍 共享内存可以从字面上去理解 xff0c 就把一片逻辑内存共享出来 xff0c 让不同的进程去访问它 xff0c 修改它 共享内存是在两个正在运行的进程之间共享和传递数据的一种非常有效的方式
  • Linux ipcs命令与ipcrm命令的用法详解

    以下是对Linux中的ipcs命令与ipcrm命令的用法进行了介绍 xff0c 需要的朋友可以过来参考下 是linux uinx上提供关于一些进程间通信方式的信息 xff0c 包括共享内存 xff0c 消息队列 xff0c 信号 ipcs用
  • c++11多线程编程 condition_variable wait notify_one notify_all 第八讲

    1 条件变量std condition variable wait notify one notify all wait 用来等一个东西 1 如果第二个参数返回值是true xff0c 那么这一行就继续往下运行 2 如果第二个参数返回值是f
  • c++11多线程 async、future、packaged_task、promise 第九讲

    1 std async std future创建后台任务并返回 2 std packaged task 3 std promise 4 小结 一 std async std future创建后台任务并返回 希望线程返回一个结果 xff1b