C++多线程基础学习笔记(七)
一、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++多线程基础学习笔记(七)的更多相关文章
- Java基础学习笔记七 Java基础语法之继承和抽象类
继承 继承的概念 在现实生活中,继承一般指的是子女继承父辈的财产.在程序中,继承描述的是事物之间的所属关系,通过继承可以使多种事物之间形成一种关系体系. 例如公司中的研发部员工和维护部员工都属于员工, ...
- C++多线程基础学习笔记(四)
一.创建多个子线程 前面三章讲的例子都是只有一个子线程和主线程,然而实际中有多个子线程.那么下面介绍如何创建多个子线程. #include <iostream> #include < ...
- C++多线程基础学习笔记(一)
下面分三个方面多线程技术的必须掌握一些基本知识. 1.进程 2.线程 3.并发 (1)进程 一个可执行程序运行起来了,即为创建了一个进程.如在电脑上打开了word,就创建了一个word进程,打开QQ, ...
- loadrunner基础学习笔记七-面向目标场景
部署应用程序之前,要执行验收测试以确保系统能够承担预期的实际工作量. 可以为想要生成的每秒点击次数,每秒事务数或事务响应时间设置目标 loadrunner将使用面向目标的场景自动生成所需的目标,当应用 ...
- JDBC一(web基础学习笔记七)
一.JDBC Java数据库的连接技术(Java DataBase Connectivity),能实现Java程序以各种数据库的访问 由一组使用Java语言编写的类和接口(JDBC API)组成,它j ...
- C++多线程基础学习笔记(十)
一.Windows临界区的基本用法 CRITICAL_SECTION my_winsc; //定义一个Windows的临界区,相当于一个mutex变量 InitializeC ...
- C++多线程基础学习笔记(九)
一.std::atomic续谈 上一章说到std::atomic是针对一个变量的,这里补充一下针对的变量操作一般是++,+=,--,&=等等运算 .以下这种不可取:a=a+1; 二.std:: ...
- C++多线程基础学习笔记(八)
shared_futrue和futrue_status的用法 shared_futrue是一个类模板,类似于futrue,不同的是它的成员函数get()可以使用多次,因为是复制数据,而futrue的g ...
- C++多线程基础学习笔记(六)
condition_variable.wait.notifiy_one.notify_all的使用方式 condition_variable:条件变量 wait:等待被唤醒 notify_one:随机 ...
随机推荐
- 9030PCI CAN驱动开发点滴
1.配置EEPROM. 使用PlxMon打开9030,基本修改Spacex(0,1,2,3), Chip selectx(0,1,2,3), 中断状态INTCSR(0x74), 其他(0x78),详细 ...
- elastic search&logstash&kibana 学习历程(一)es基础环境的搭建
elastic search 6.1.x 常用框架: 1.Lucene Apache下面的一个开源项目,高性能的.可扩展的工具库,提供搜索的基本架构: 如果开发人员需用使用的话,需用自己进行开发,成本 ...
- 一、MySQL一些简述
概述 数据库(database) : 保存有组织的数据的容器(通常是一个文件或一组文件). 主键(primary key): 唯一标识表中每行的这个列(或这组列)称为主键.主键用表示一个特定的行.没有 ...
- HNOI2012矿场搭建
做完Mining Your Own Business后觉得这个题没什么意思了,数据范围小的连边数不清空都能A. 题解直接看这篇吧.做题的经历也挺……对吧. #include<iostream&g ...
- Spring之Bean管理------注解方式
编写测试类 1,编写相关的类 public interface UserDao { public void sayHello(); } public class UserDaoImpl impleme ...
- 黑马vue---8-10、v-cloak、v-text、v-html、v-bind、v-on的基本使用
黑马vue---8-10.v-cloak.v-text.v-html.v-bind.v-on的基本使用 一.总结 一句话总结: v-bind等这些东西都是用的vue.data里面的变量 1.使用 v- ...
- koa 项目实战(二)连接 mongodb 数据库
1.配置文件 根目录/config/keys.js module.exports = { mongoURI: 'mongodb://127.0.0.1:27017/mongodb' } 2.启动文件 ...
- MySQL基础普及《MySQL管理之道:性能调优、高可用与监控》
最近工作的内容涉及MySQL运维内容,陆陆续续读了几本相关的书,其中一本是<MySQL管理之道:性能调优.高可用与监控>. 内容涵盖性能调优(包括sql优化等).备份.高可用,以及读写分离 ...
- IIS asp.net 中出现未能加载文件或程序集“System.Core, Version=3.5.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089”或它的某一个依赖项。系统找不到指定的文件。
分析器错误消息: 未能加载文件或程序集“System.Core, Version=3.5.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089”或 ...
- ButterKnifer使用
ButterKnifer使用 1.集成 github地址: https://github.com/JakeWharton/butterknife 1.1在主Moduel中的使用 在主moduel中的b ...