十、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 ...
随机推荐
- I am going to India on a business trip
I think English is very important,and learn it must perseverant.So I determined to write diary on Bo ...
- day23—JavaScript实现DIV盒子拖拽(原生方式)
转行学开发,代码100天——2018-04-08 <!doctype html> <html> <head> <meta charset="utf- ...
- 【经验分享】 解决CentOS7 安装VMTools提示找不到Kernel头文件的方案
配置一个Linux的开发环境,用VM10+CentOS7(Kernel版本3.10.0-327.10.1.el7),之后发现VMTools功能不全,查证后发现需要卸载重装,于是开始折腾. 按照各种说明 ...
- cts测试流程
测试目的: 用于检测你做的Android系统是否满足兼容性要求,通俗点说,Google认为Android系统应该满足的条件,你需要满足. 例如框架层暴露给应用层的某些接口,Google认为你因该有,那 ...
- 进程池Pool的简单使用,同步异步的区别
#进程池 """ 当需要创建子进程数量不多的时候,可以直接利用multiprocessing 中的Process动态生成多个进程,但是如果上百甚至上千个任务, " ...
- PHP_CodeIgniter Github实现个人空间
github支持github Pages 可以实现自己的个人空间 XXX.github.io/project 1 注册自己的github账户 2 需要设置自己的user_name, user_name ...
- react 渲染顺序
工作中要对一个表格做再次更新, 可能是渲染后更新或者部分组件渲染之后, 对页面效果做处理 之前对react的理解, 仅仅停留在render渲染. 这次好好理解了下react的生命周期 1 react组 ...
- GnuTLS 3.3.3 remote memory corruption(CVE-2014-3466)
Buffer overflow in the read_server_hello function in lib/gnutls_handshake.c in GnuTLS before 3.1.25, ...
- NGUI的窗体的推动和调节大小(drag object和drag resize object)
一,我们先添加一个sprite,给sprite添加一个背景图片,然后attach添加一个box Collider,但是这时我们右键attach是找不到drag object的我们需要在add comp ...
- JS中的reduce函数
海纳百川,有容乃大 定义: reduce()方法接受一个函数作为累加器,数组中的每个值(从左向右)开始缩减,最终计算为一个值.对空数组是不会执行回调函数的. 案例: 计算数组总和: var num = ...