• C++11 原子变量


    目录

    什么时原子变量?

    atomic 类成员

    原子变量的使用


    C/C++Linux服务器开发/后台架构师【零声教育】-学习视频教程-腾讯课堂

    什么时原子变量?

    原子操作

            原子指的是一系列不被 CPU上下文交换的机器指令,这些指令组合在一起就形成了原子操作。在多核 CPU 下,当某个CPU开始运行原子操作时,会先暂停其它 CPU 内核对内存的操作,以保证原子操作被其它 CPU 内核所干扰。

    C++11内置了整形的原子变量

            C++11提供了一个原子类型std::atomic,可以通过这个原子类型管理的内部变量就可以称之为原子变量,我们可以给原子类型指定 bool、char、int、long、指针等类型作为模板参数使用。

            在多线程操作中,使用原子变量之后就不需要再使用互斥量来保护该变量了,用起来更简洁。因为对原子变量进行的操作只能是一个原子操作(atomic operation),原子操作指的是不会被线程调度机制打断的操作,这种操作一旦开始,就一直运行到结束,中间不会有任何的上下文切换。

            多线程同时访问共享资源造成数据混乱的原因就是因为 CPU 的上下文切换导致的,使用原子变量解决了这个问题,因此互斥锁的使用也就不再需要了。

    atomic 类成员

    1. 原子地以 desired 替换当前值。按照 order 的值影响内存。

    desired:存储到原子变量中的值

    order:强制的内存顺序

    1. void store( T desired, std::memory_order order = std::memory_order_seq_cst ) noexcept;
    2. void store( T desired, std::memory_order order = std::memory_order_seq_cst ) volatile noexcept;

    2. 原子地加载并返回原子变量的当前值。按照order的值影响内存。直接访问原子对象也可以得到原子变量的当前值。

    1. T load( std::memory_order order = std::memory_order_seq_cst ) const noexcept;
    2. T load( std::memory_order order = std::memory_order_seq_cst ) const volatile noexcept;

            内存顺序约束

    1. typedef enum memory_order {
    2.     memory_order_relaxed,   // relaxed
    3.     memory_order_consume,   // consume
    4.     memory_order_acquire,   // acquire
    5.     memory_order_release,   // release
    6.     memory_order_acq_rel,   // acquire/release
    7.     memory_order_seq_cst    // sequentially consistent
    8. } memory_order;

    原子变量的使用

    1. #include <iostream>
    2. #include <thread>
    3. #include <atomic>
    4. #include <functional>
    5. using namespace std;
    6. //std::atomic<int> m_value = 0;//错误初始化
    7. //atomic_int m_value = 0; // 准确初始化
    8. std::atomic<int> m_value(0); // 准确初始化
    9. void increment()
    10. {
    11. for (int i = 0; i < 5; ++i)
    12. {
    13. m_value++;
    14. cout << i <<"increment number: " << m_value << ", theadID: " << this_thread::get_id() << endl;
    15. this_thread::sleep_for(chrono::milliseconds(500));
    16. }
    17. }
    18. void decrement()
    19. {
    20. for (int i = 0; i < 5; ++i)
    21. {
    22. m_value--;
    23. cout << i << "decrement number: " << m_value << ", theadID: " << this_thread::get_id() << endl;
    24. this_thread::sleep_for(chrono::milliseconds(500));
    25. }
    26. }
    27. int main()
    28. {
    29. thread t1(increment);
    30. thread t2(decrement);
    31. t1.join();
    32. t2.join();
    33. return 0;
    34. }

  • 相关阅读:
    [附源码]计算机毕业设计JAVA疫情状态下病房管理平台
    【网络爬虫笔记】爬虫Robots协议语法详解
    SQL基础理论篇(一):什么是SQL
    再见RestTemplate,Spring 6.1新特性:RestClient 了解一下!
    Jupyter Notebook 如何切换虚拟环境
    C++ 不同继承之间的的关系
    走进 AnyTrust 技术底层,数据可用性和最小信任假设如何实现
    零基础学习JS--基础篇--元编程
    go-zero微服务入门教程
    各城市web相关职业招聘数据个人统计
  • 原文地址:https://blog.csdn.net/kakaka666/article/details/127933579