一、std::async和std::future的用法

std::async是一个函数模板,std::future是一个类模板

 #include <iostream>
#include <thread>
#include <future>
#include <Windows.h> using namespace std; int mythread()
{
cout << "my thread:" << std::this_thread::get_id() << " start" << endl;
int temp = ;
temp++;
Sleep();
cout << "my thread:" << std::this_thread::get_id() << " end" << endl;
return temp;
}
int main()
{
cout << "main thread:" << std::this_thread::get_id() << " start" << endl;
std::future<int> result = std::async(std::launch::async, mythread);
//std::async(mythread);相当于std::async(std::launch::async|std::lauch::deferred, mythread);
//自动创建一个线程开始执行线程入口函数,并返回一个std::future对象给result cout << result.get() << endl; //等待入口函数执行,直到拿到返回值,即temp
//result.wait(); //只等待入口函数执行完,但不返回结果
cout << "main thread:" << std::this_thread::get_id() << " end" << endl;
system("pause");
return ;
}

std::async(std::launch::async, mythread);如果std::async()的第一个参数改成std::lauch::deferred,那么线程不会被马上执行,而是延迟到std::future的wait()或者get()函数调用时才执行线程的入口函数。实际上,并没有创建
子线程,而只是在主函数中调用了入口函数。
二、std::packaged_task的用法
std::packaged_task是一个类模板,模板参数各种可调用对象,通过它把各种可调用对象包装起来,方便作为线程入口函数来调用
 #include <iostream>
#include <thread>
#include <future>
#include <Windows.h> using namespace std; int fun(int val)
{
cout << "my thread:" << std::this_thread::get_id() << " start" << endl;
val++;
cout << "my thread:" << std::this_thread::get_id() << " end" << endl;
return val;
}
int main()
{
cout << "main thread:" << std::this_thread::get_id() << " start" << endl;
std::packaged_task<int(int)> pack(fun);
thread t1(std::ref(pack), );
t1.join();
std::future<int> result = pack.get_future();
cout << result.get() << endl;
cout << "main thread:" << std::this_thread::get_id() << " end" << endl;
system("pause");
return ;
}

三、std::promise的用法

std::promise是一个类模板,能够在某个线程中给它赋值,然后可以在其他线程中,在将来的某个时刻,可以把这个值取出来。

 #include <iostream>
#include <thread>
#include <future>
#include <Windows.h> using namespace std; void mythread1(std::promise<int> &pro, int val)
{
cout << "my thread1:" << std::this_thread::get_id() << " start" << endl;
val++;
val--;
Sleep(); //假设运算了500毫秒
int result = val;
pro.set_value(val);//保存结果
cout << "my thread1:" << std::this_thread::get_id() << " end" << endl;
} void mythread2(std::future<int> &getful)
{
cout << "my thread2:" << std::this_thread::get_id() << " start" << endl;
auto getval = getful.get();
cout << getval << endl;
cout << "my thread2:" << std::this_thread::get_id() << " end" << endl;
}
int main()
{
cout << "main thread:" << std::this_thread::get_id() << " start" << endl;
std::promise<int> prom; //声明一个promise对象,保存类型为int
thread t1(mythread1, std::ref(prom), );
t1.join(); std::future<int> ful = prom.get_future(); //promise和future绑定,用于返回保存的结果 //在主线程获取结果
//auto result = ful.get(); //get()只能使用一次,如果主线程中使用了,t2就不能使用了
//cout << result << endl; //在线程t2中获取结果
thread t2(mythread2, std::ref(ful));
t2.join(); cout << "main thread:" << std::this_thread::get_id() << " end" << endl;
system("pause");
return ;
}

std::ref 用于包装按引用传递的值。

												

C++多线程基础学习笔记(七)的更多相关文章

  1. Java基础学习笔记七 Java基础语法之继承和抽象类

    继承 继承的概念 在现实生活中,继承一般指的是子女继承父辈的财产.在程序中,继承描述的是事物之间的所属关系,通过继承可以使多种事物之间形成一种关系体系. 例如公司中的研发部员工和维护部员工都属于员工, ...

  2. C++多线程基础学习笔记(四)

    一.创建多个子线程 前面三章讲的例子都是只有一个子线程和主线程,然而实际中有多个子线程.那么下面介绍如何创建多个子线程. #include <iostream> #include < ...

  3. C++多线程基础学习笔记(一)

    下面分三个方面多线程技术的必须掌握一些基本知识. 1.进程 2.线程 3.并发 (1)进程 一个可执行程序运行起来了,即为创建了一个进程.如在电脑上打开了word,就创建了一个word进程,打开QQ, ...

  4. loadrunner基础学习笔记七-面向目标场景

    部署应用程序之前,要执行验收测试以确保系统能够承担预期的实际工作量. 可以为想要生成的每秒点击次数,每秒事务数或事务响应时间设置目标 loadrunner将使用面向目标的场景自动生成所需的目标,当应用 ...

  5. JDBC一(web基础学习笔记七)

    一.JDBC Java数据库的连接技术(Java DataBase Connectivity),能实现Java程序以各种数据库的访问 由一组使用Java语言编写的类和接口(JDBC API)组成,它j ...

  6. C++多线程基础学习笔记(十)

    一.Windows临界区的基本用法 CRITICAL_SECTION my_winsc;              //定义一个Windows的临界区,相当于一个mutex变量 InitializeC ...

  7. C++多线程基础学习笔记(九)

    一.std::atomic续谈 上一章说到std::atomic是针对一个变量的,这里补充一下针对的变量操作一般是++,+=,--,&=等等运算 .以下这种不可取:a=a+1; 二.std:: ...

  8. C++多线程基础学习笔记(八)

    shared_futrue和futrue_status的用法 shared_futrue是一个类模板,类似于futrue,不同的是它的成员函数get()可以使用多次,因为是复制数据,而futrue的g ...

  9. C++多线程基础学习笔记(六)

    condition_variable.wait.notifiy_one.notify_all的使用方式 condition_variable:条件变量 wait:等待被唤醒 notify_one:随机 ...

随机推荐

  1. mac重启php7.0

    killall php-fpm /usr/local/opt/php70/sbin/php70-fpm restart

  2. Android_(控件)使用ListView显示Android系统SD卡的文件列表_02

    使用ListView显示Android SD卡中的文件列表 父类布局activity_main.xml,子类布局item_filelayout(一个文件的单独存放) 运行截图: 程序结构 <?x ...

  3. HNOI2015菜肴制作

    一开始,没想出来,先topsort判环,把impossible拿到手,然后划分联通块,对每个联通块跑一遍topsort,觉得可对了,然后被大样例教育明白了,知道自己的策略错在哪了. 接着在纸上疯狂手模 ...

  4. anaconda环境管理

    创建新环境 conda create -n rcnn python=3.6 删除环境 conda remove -n rcnn --all 重命名环境 参考SO:https://stackoverfl ...

  5. mysql使用命令行执行存储过程

    编写存储过程sql 以给brand表添加phone字段为例: DROP PROCEDURE IF EXISTS UpdateColum; CREATE PROCEDURE UpdateColum() ...

  6. git *** Please tell me who you are.错误

    GIT 中提示 please tell me who you are   如果使用git过程中出现了,please tell me who you are ,需要设置一下使用者的身份. 1.git c ...

  7. Alert 警告

    基本用法 页面中的非浮层元素,不会自动消失. Alert 组件提供四种主题,由type属性指定,默认值为info. <template> <el-alert title=" ...

  8. vs install 安装时自动添加注册表

    思路:使用自定义 解决方案添加类库项目 添加安装程序类 随后右键查看代码 在构造函数添加事件 同时完成这个事件,在此事件中根据需要添加我们需要的内容,此处为添加注册表,并根据安装目录添加url pro ...

  9. 集成学习之Adaboost算法原理

    在boosting系列算法中,Adaboost是最著名的算法之一.Adaboost既可以用作分类,也可以用作回归. 1. boosting算法基本原理 集成学习原理中,boosting系列算法的思想:

  10. WCF绑定(Binding)

    一个Binding由一个有序的binding元素栈所组成,其中的每一个元素都指定了连接到ServiceEndpoint的一个方面.在这个栈中的最底两层都是必须要有的.最底下的一层是传输binding元 ...