• std::atomic
  • std::async

std::atomic

一般atomic原子操作,针对++,--,+=,^=是支持的,其他结果可能不支持。

注意

std::atomic<int> g_varibale = 0;

....
int f(){
g_varibale = g_varibale +1; //这样的写法有问题
}

  很多时候,写程序简单就是美,不太建议把程序写得复杂。多线程程序要求稳定,然后在稳定的基础上去扩展功能。

std::async参数详解

async是用来创建一个异步任务,比如

int mythread()
{
cout << "This thread "<<std::this_thread::get_id()<<endl;
return 1;
}

  在main中:

std::future<int> result = std::async(mythread);
cout << result.get()<<endl;

  程序的执行结果为1)启动一个线程 2)最终线程返回1。

延迟调用的参数:std::launch::deferred,以及std::launch::async 这个参数是强制创建一个线程。

std::thread是用来创建一个线程的,如果创建线程过多,系统资源紧张,那么创建线程就会失败,那么程序就会失败,那么执行std::thread时程序可能崩溃。

std::async一般不叫它创建线程,一般是创建一个异步任务,有时候并不创建新的线程。

a) 如果用std::launch::deferred来调用async,用了deferred之后是延迟调用,并且不创建新线程,延迟到future对象调用get或者wait的时候才执行函数。

b) std::launch::async,强制异步任务在新线程上执行,这意味着系统必须要创建出新线程来执行函数。

c) 如果同时用到deferred和async,即std::launch::async | std::launch::deferred,此时"或":意味着调用async的行为可能是创建新线程并立即执行,或者是没有创建新线程,并且延迟调用,直到get时候才开始执行任务,两者居其一。系统会根据一定的因素,自动分配。此时有不确定性,那么写程序的时候就要注意是否创建新线程来运行。

d) 如果不带而外参数,只给async函数一个入口函数名。当没有指定async和deferred,默认值是c)中两者都有的效果完全一致,系统会自行决定是同步还是异步执行。如果是异步,那么创建新线程,而如果是同步,那么不创建新线程。

e)系统如何决定是异步还是同步?

std::thread是一定会创建线程,a)如果系统资源紧张,那么程序会报异常,然后程序退出。 b)用thread创建线程,往往会复制变量到线程中,如果要拿到返回值,需要一个全局量或者其他方式。std::async和std::thead不同,async是创建一个异步任务,可能创建线程,也可能不创建线程,并且async调用方法,很容易得到线程的返回值,这个是async的优势。由于系统资源限制,

(1)如果用std::thread创建的线程太多,创建失败时,系统崩溃。

(2)如果用async就不会报异常,如果系统资源紧张,导致无法创建新的线程,这种不加额外参数的调用,就不会创建新线程,而是后续谁调用了get,这个异步任务就运行在执行这条get的语句所在的线程上。

(3)一个程序里,线程数量不应超过100-200。

std::async不确定性的解决

不加额外参数的std::async,让系统自行决定是否创建新线程,存在不确定性,写程序的时候就会出现问题。

问题的焦点在于std::future<int> result = std::async(mythread)这个异步任务是否被推迟执行,std::future对象的wait_for 函数

C++并发与多线程学习笔记--atomic的更多相关文章

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

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

  2. C++并发与多线程学习笔记--基本概念和实现

    基本概念 并发 可执行程序.进程.线程 学习心得 并发的实现方法 多进程并发 多线程并发 总结 C++标准库 基本概念 (并发.进程.线程)区分C++初级编程和中高级编程 并发 两个或者更多的任务同时 ...

  3. C++并发与多线程学习笔记--互斥量、用法、死锁概念

    互斥量(mutex)的基本概念 互斥量的用法 lock(), unlock() std::lock_guard类模板 死锁 死锁演示 死锁的一般解决方案 std::lock()函数模板 std::lo ...

  4. C++并发与多线程学习笔记--单例设计模式、共享数据分析

    设计模式 共享数据分析 call_once 设计模式 开发程序中的一些特殊写法,这些写法和常规写法不一样,但是程序灵活,维护起来方便,别人接管起来,阅读代码的时候都会很痛苦.用设计模式理念写出来的代码 ...

  5. C++并发与多线程学习笔记--多线程数据共享问题

    创建和等待多个线程 数据和共享问题分析 只读的数据 有读有写 其他案例 共享数据的保护案例代码 创建和等待多个线程 服务端后台开发就需要多个线程执行不同的任务.不同的线程执行不同任务,并返回执行结果. ...

  6. C++并发与多线程学习笔记--参数传递详解

    传递临时对象 陷阱 总结 临时对象作为线程参数 线程id的概念 临时对象构造时的抓捕 成员函数指针做线程函数 传递临时对象作为线程参数 创建的工作线程不止一个,线程根据编号来确定工作内容.每个线程都需 ...

  7. C++并发与多线程学习笔记--async、future、packaged_task、promise

    async future packaged_task promise async std:async 是个函数,用来启动一个异步任务,启动起来一个异步任务之后,返回一个std::futre对象,启动一 ...

  8. C++并发与多线程学习笔记--线程之间调度

    condition_variable wait() notify_one notify_all condition_variable 条件变量的实际用途: 比如有两个线程A和B,在线程A中等待一个条件 ...

  9. C++并发与多线程学习笔记--unique_lock详解

    unique_lock 取代lock_quard unique_lock 的第二个参数 std::adopt_lock std::try_to_lock std::defer_lock unique_ ...

随机推荐

  1. HTTP/HTTPS Proxy & Charles

    HTTP/HTTPS Proxy & Charles Charles https://www.charlesproxy.com/ https://www.jianshu.com/p/53d2c ...

  2. HTML Custom Elements & valid name

    HTML Custom Elements & valid name valid custom element name https://html.spec.whatwg.org/multipa ...

  3. Angular 2020

    Angular 2020 https://angular.io/start https://angular.io/guide/browser-support "@angular/core&q ...

  4. QR code & auto login & OAuth 2.0

    QR code & auto login & OAuth 2.0 扫码自动登录原理解析 https://www.ximalaya.com/shangye/14685881/958686 ...

  5. git hooks & pre-commit

    git hooks & pre-commit

  6. call、apply和bind的实现

    call方法 基础版, 只能修改指向,不能传参 Function.prototype.myCall = function(context) { // 获取调用者,这里为bar context.fn = ...

  7. docket 缺陷

    docker轻量级的虚拟机 依赖于内存和核数 相比于正常的虚拟机来说运行速度会慢

  8. Vue脚手架中默认的margin怎么清除

    问题情景:开发中发现我的项目四周有白边,但是并没有设置样式 问题原因:vue脚手架中静态文件夹public中的index.html造成的 解决方案:找到vue脚手架中index.html页面,设置ma ...

  9. DRF 三大认证之身份认证

    目录 路由组件补充 三大认证 一.身份认证 1.如何进行身份认证 2.jwt认证规则原理 3.jwt的组成 4.jwt的使用方法 4.1 签发算法 4.2 校验算法 4.3 刷新算法 二.权限认证 三 ...

  10. TcaplusDB服务体系揭秘

    导言 TcaplusDB是腾讯出品的分布式NoSQL数据库,存储和调度的代码完全自研.具备缓存+落地融合架构.PB级存储.毫秒级时延.无损水平扩展和复杂数据结构等特性.同时具备丰富的生态.便捷的迁移. ...