十、future其他成员函数、shared_future、atomic(原子操作)
一、
int mythread(){
cout<<"thread"<<endl;
std::chrono::milliseconds dura();//5秒钟
std::this_thread::sleep_for(dura);//休息5秒钟
return ;
} int main(){
std::future<int> result = std::async(mythread); //是个枚举类型有ready,timeout,deferred
std::future_status status = result.wait_for(std::chrono::second());//等1秒,
if(status==std::future_status::timeout){
//线程要执行5秒,这里只等待1秒,希望你返回,你没有返回那么status 是 timeout
}
else if(status==std::future_status::timeout){
//表示线程成功返回
cout << result.get() <<endl;
}
else if(status==std::future_status::deffered){
//如果saync第一个参数设置这个deffered,这个线程被延迟执行
//遇到get线程才会执行,mythread会在主线程中执行(相当于在主线程中的一个函数调用),就不是真正意义上的子线程了
cout<<res.get()<<endl;
}
}
shared_future
类模板,使用get函数时就是复制了,第二次使用get还会成功
int mythread(){
cout<<"thread"<<endl;
std::chrono::milliseconds dura();//5秒钟
std::this_thread::sleep_for(dura);//休息5秒钟
return ;
} int main(){
std::future<int> result = mypt.get_future();
std::shared_future<int> result_s(std::move(result));//move变成右值,将result 过渡给了result_s,result里就空了,移动语义
//不能直接用result_s(result),会报错,接受的是一个右值属性的,所以要用move变成右值属性
//这样也可以:std::shared_future<int> result_s(result.share());
ifcanget = result_s.valid();//true or false }
原子操作
互斥量:多线程编程中,保护共享数据
锁:操作共享数据,开锁
有两个线程,对一个变量进行操作,这个线程读该变量值,另一个线程往这个线程中写值。
A线程: tmp = bbb;//bbb是多线程中共享的变量
B线程: bbb = 6;
注意:B中的赋值语句,会有多个操作步骤(汇编中可能有n多行汇编代码),有可能你执行到汇编代码第x行的时候线程B就切出去了,这个时候A读到的变量就是B赋值过程中的中间值。
解决这个问题可以用互斥量,但是这样效率会很慢。
使用原子操作就能够解决这个问题,类似于锁,但是效率比互斥量高很多。保证赋值这个操作执行完。
可以把原子操作理解为一种,不需要互斥量加锁(无锁)技术的多线程并发变成方式
也可以理解为在多线程中,不会被打断程序执行片断,无锁操作,比互斥量效率高。
一般互斥量针对一个代码段(几行代码),而原子操作针对一个变量,而不是代码段。
原子操作:指不可分割的操作,也就是说这种操作状态要么是完成的,要么是没完成的,不能出现半完成状态。
std::atomic类模板,用来封装某个类型的值
std::automic<int> g_mycount = ;//封装了一个类型为int的对象,可以像操作一个int变量一样来操作g_mycount //g_mycount++;是一个原子操作,每一次的操作不会被打断 void mythread(){
std::chrono::milliseconds dura();//
while(g_ifend==false){
std::this_thread::sleep_for(dura);//没一秒钟判断一次g_ifend
}
cout<<"结束"<<endl;
return;
} int main(){
thread my1(mythread);
thread my2(mythread);
std::chrono::milliseconds dura();
std::this_thread::sleep_for(dura);
g_ifend = true;
my1.join();
my2.join();
cout<<"end"<<endl;
}
十、future其他成员函数、shared_future、atomic(原子操作)的更多相关文章
- C++并发与多线程学习笔记--future成员函数、shared_future、atomic
std::future的其他成员函数 std::shared_future 原子操作.概念.基本用法 多线程主要是为了执行某个函数,本文的函数的例子,采用如下写法 int mythread() { c ...
- 条目二十八《正确理解由reverse_iterator的base()成员函数所产生的iterator的用法》
条目二十八<正确理解由reverse_iterator的base()成员函数所产生的iterator的用法> 迭代器的种类一共有四种,上面已经说过了.这里就不再次写出来. 这一个条目主要是 ...
- 读书笔记_Effective_C++_条款四十五:运用成员函数模板接受所有兼容类型
比如有一个Base类和一个Derived类,像下面这样: class BaseClass {…}; class DerivedClass : public BaseClass {…}; 因为是父类与子 ...
- C++(三十二) — 常对象、常成员变量、常成员函数
常量:对于既需要共享.又需要防止改变的数据.在程序运行期间不可改变. const 修饰的是对象中的 this 指针.所以不能被修改. 1.常对象 数据成员值在对象的整个生存期内不能改变.在定义时必须初 ...
- C++(十六) — 类中引用成员函数、命名空间的使用
1.为什么类中引用成员函数? 类将属性和方法做了封装.类是一种数据类型,也就是:固定大小内存块的别名. 类的定义是一个抽象的概念,定义时不分配内存,当用类定义对象时,才分配一个固定大小的内存块. 此时 ...
- Item 16: 让const成员函数做到线程安全
本文翻译自modern effective C++,由于水平有限,故无法保证翻译完全正确,欢迎指出错误.谢谢! 博客已经迁移到这里啦 如果我们在数学领域里工作,我们可能会发现用一个类来表示多项式会很方 ...
- 并发之java.util.concurrent.atomic原子操作类包
15.JDK1.8的Java.util.concurrent.atomic包小结 14.Java中Atomic包的原理和分析 13.java.util.concurrent.atomic原子操作类包 ...
- atomic 原子操作
原子操作:操作仅由一个独立的CPU指令代表和完成.保证并发环境下原子操作的绝对安全 标准库代码包:sync/atomic atomic是最轻量级的锁,在一些场景下直接使用atomic包还是很有效的 C ...
- C++11开发中的Atomic原子操作
C++11开发中的Atomic原子操作 Nicol的博客铭 原文 https://taozj.org/2016/09/C-11%E5%BC%80%E5%8F%91%E4%B8%AD%E7%9A%84 ...
随机推荐
- STM32 HAL库关于串口中断烧录程序后可以正常运行,断电重启后无法进入中断的问题分析以及解决方法
1.情景描述: 最近在做一个项目,X86的上位机通过串口控制MCU,使用串口中断接收上位机数据时,MCU在上电的情况下烧录程序,可以正常接收上位机的数据,在断电重启后,一直进入不了中断回调函数,上电的 ...
- Vagrant 手册之 Provisioning - Shell 配置程序
原文地址 Provisioner 命令:"shell" 示例: node.vm.provision "shell" do |s| s.inline = < ...
- HBase备份还原OpenTSDB数据之Export/Import(增量+全量)
前言 本文基于伪分布式搭建 hadoop+zookeeper+hbase+opentsdb之后,文章链接:https://www.cnblogs.com/yybrhr/p/11128149.html, ...
- 关于Nuget包安装之后再卸载,找不到dll的问题
场景: 在nuget上安装了FFTW.NET,自动的安装一堆其依赖的dll,那些dll都是donet自带的.再卸载这些dll的时候,项目可以生成成功,就是跑不起来.提示如下: 解决方案: 经过排查发现 ...
- ThreadLocal和单例对象比较
单例对象: 自始至终只有一个对象 当线程并发,每个线程需要自己独立的资源变量处理不同的业务时,单例对象远远不能满足需求 因此可以采用ThreadLocal模式 : 每个线程有自己独立的资源变量 ...
- Django文件上传下载与富文本编辑框
django文件上传下载 上传 配置settings.py # 设定文件的访问路径,如:访问http://127.0.0.1:8000/media/就可以获取文件 MEDIA_URL = '/medi ...
- 专题:性能调优之工具---perf
1. Linux Perf简介 1.1 Perf是什么 Perf 是内置于Linux 内核源码树中的性能剖析(profiling)工具.它基于事件采样原理,以性能事件为基础,支持针对处理器相关性能指标 ...
- JavaScript 各种遍历方式详解及总结
JavaScript 各种遍历方式详解 在$.each中想要终止循环,但是它没有continue或者break这样的终止方式,所以尝试使用return来进行终止,但是发现并没有跳出循环.为了搞清楚js ...
- C#设计模式:策略者模式(Stragety Pattern)
一,什么是策略模式? 1,针对同一命令或行为,不同的策略做不同的动作. 2,比如针对一组算法,将每个算法封装到具有公共接口的独立的类中,从而使它们可以相互替换.策略模式使得算法可以在不影响到客户端的情 ...
- JavaScript 中的 Function.prototype.bind() 方法
转载自:https://www.cnblogs.com/zztt/p/4122352.html Function.prototype.bind()方法 bind() 方法的主要作用就是将函数绑定至某个 ...