一、

 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. C#联接序列

    1.  Concat() – 串联序列(有重复项) var healthFoods = new List<string> { "fruits", "veget ...

  2. JavaScript GetAbsoultURl

    var img = document.createElement('A');     img.src = "/img/weixin.jpg";  // 设置相对路径给Image,  ...

  3. Runnable、Callable、Future、FutureTask的区别

    转自:https://blog.csdn.net/jdsjlzx/article/details/52912701 FutureTask既是Future.Runnable,又是包装了Callable( ...

  4. spring-第一篇之spring核心机制依赖注入(DI)/控制翻转(IoC)

    1.spring的核心机制:依赖注入(DI)/控制翻转(IoC) 什么是依赖:A对象需要调用B对象,所以A依赖于B. 什么是注入:A对象注入一个属性B对象. 什么是依赖注入(DI):A对象依赖于B对象 ...

  5. P4158[SCOI2009]粉刷匠

    题目描述 windy有 N 条木板需要被粉刷. 每条木板被分为 M 个格子. 每个格子要被刷成红色或蓝色. windy每次粉刷,只能选择一条木板上一段连续的格子,然后涂上一种颜色. 每个格子最多只能被 ...

  6. 让 Git Bisect 帮助你

    让 Git Bisect 帮助你 英文原文:Letting Git Bisect Help You   Git 提供来很多的工具来帮助我们改进工作流程. bisect 命令就是其中之一, 虽然由于使用 ...

  7. 为什么MySQL索引要使用 B+树,而不是其它树形结构?

    作者:李平 https://www.cnblogs.com/leefreeman/p/8315844.html 一个问题? InnoDB一棵B+树可以存放多少行数据?这个问题的简单回答是:约2千万 为 ...

  8. 20180119-文件操作open用法

    官方文档 open(file, mode='r', buffering=-1, encoding=None, errors=None, newline=None, closefd=True, open ...

  9. 2018-8-10-win10-uwp-毛玻璃

    title author date CreateTime categories win10 uwp 毛玻璃 lindexi 2018-08-10 19:16:50 +0800 2018-2-13 17 ...

  10. Codeforces Round #394 (Div. 2) - C

    题目链接:http://codeforces.com/contest/761/problem/C 题意:给定n个长度为m的字符串.每个字符串(字符串下标从0到m-1)都有一个指针,初始指针指向第0个位 ...