一、

 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(原子操作)的更多相关文章

  1. C++并发与多线程学习笔记--future成员函数、shared_future、atomic

    std::future的其他成员函数 std::shared_future 原子操作.概念.基本用法 多线程主要是为了执行某个函数,本文的函数的例子,采用如下写法 int mythread() { c ...

  2. 条目二十八《正确理解由reverse_iterator的base()成员函数所产生的iterator的用法》

    条目二十八<正确理解由reverse_iterator的base()成员函数所产生的iterator的用法> 迭代器的种类一共有四种,上面已经说过了.这里就不再次写出来. 这一个条目主要是 ...

  3. 读书笔记_Effective_C++_条款四十五:运用成员函数模板接受所有兼容类型

    比如有一个Base类和一个Derived类,像下面这样: class BaseClass {…}; class DerivedClass : public BaseClass {…}; 因为是父类与子 ...

  4. C++(三十二) — 常对象、常成员变量、常成员函数

    常量:对于既需要共享.又需要防止改变的数据.在程序运行期间不可改变. const 修饰的是对象中的 this 指针.所以不能被修改. 1.常对象 数据成员值在对象的整个生存期内不能改变.在定义时必须初 ...

  5. C++(十六) — 类中引用成员函数、命名空间的使用

    1.为什么类中引用成员函数? 类将属性和方法做了封装.类是一种数据类型,也就是:固定大小内存块的别名. 类的定义是一个抽象的概念,定义时不分配内存,当用类定义对象时,才分配一个固定大小的内存块. 此时 ...

  6. Item 16: 让const成员函数做到线程安全

    本文翻译自modern effective C++,由于水平有限,故无法保证翻译完全正确,欢迎指出错误.谢谢! 博客已经迁移到这里啦 如果我们在数学领域里工作,我们可能会发现用一个类来表示多项式会很方 ...

  7. 并发之java.util.concurrent.atomic原子操作类包

    15.JDK1.8的Java.util.concurrent.atomic包小结 14.Java中Atomic包的原理和分析 13.java.util.concurrent.atomic原子操作类包 ...

  8. atomic 原子操作

    原子操作:操作仅由一个独立的CPU指令代表和完成.保证并发环境下原子操作的绝对安全 标准库代码包:sync/atomic atomic是最轻量级的锁,在一些场景下直接使用atomic包还是很有效的 C ...

  9. 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 ...

随机推荐

  1. 多个springboot项目部署到tomcat,Error deploying web application archive

    每个springboot单独部署到tomcat下可以正常启动,多个一个就发生异常 Error deploying web application archive 解决:配置文件加上配置区分 sprin ...

  2. 标准标签库JSTL(JSP Standard Tag Library)

    1, 核心标签(最常用, 最重要的) 表达式控制标签 out 输出常量 value---直接赋值 输出变量 default---默认值 escapeXml---控制转义字符(默认为true, 如果需要 ...

  3. Netty内存池及命中缓存的分配

    内存池的内存规格: 在前面的源码分析过程中,关于内存规格大小我们应该还有些印象.其实在Netty 内存池中主要设置了四种规格大小的内存:tiny 是指0-512Byte 之间的规格大小,small 是 ...

  4. spring-第五篇之spring容器中的bean

    1.bean的基本定义和bean别名 2.容器中bean的作用域 singleton:单例模式,在整个spring IoC容器中,singleton作用域的bean将只生成一个实例. prototyp ...

  5. 【五一qbxt】day5 图论

    图论 学好图论的基础: 必须意识到图论hendanteng xuehuifangqi(雾 图 G = (V,E) 一般来说,图的存储难度主要在记录边的信息 无向图的存储中,只需要将一条无向边拆成两条即 ...

  6. dp(不连续和)

      I - I HDU - 2845   Bean-eating is an interesting game, everyone owns an M*N matrix, which is fille ...

  7. php提交表单时如何保留多个空格及换行的文本样式

    需求是:用户提交表单时屏蔽敏感词的功能.其中敏感词来自服务器端同一路径下的ciku.txt,敏感词通过"|"连接,例如"g|c|a",提交表单时替换敏感词,更重 ...

  8. 复制书稿 (dp+贪心)

    [题目描述] 现在要把m本有顺序的书分给k个人复制(抄写),每一个人的抄写速度都一样,一本书不允许给两个(或以上)的人抄写,分给每一个人的书,必须是连续的,比如不能把第一.第三和第四本书给同一个人抄写 ...

  9. P4843 清理雪道(上下界网络流)

    P4843 清理雪道 上下界最小流 我们先搞一遍上下界可行流(转) 回忆上下界最大流的写法:在可行流的残量网络$s\ -\ t$上跑最大流,答案为可行流$+$残量网络的最大流 那么上下界最小流的写法呢 ...

  10. 攻防世界--maze

    测试文件下载:https://adworld.xctf.org.cn/media/task/attachments/fa4c78d25eea4081864918803996e615 1.准备 获得信息 ...