CAS与原子操作

什么是原子操作?
  • 原子操作是一种在执行过程中不会被中断的操作。它要么完全执行成功,要么完全不执行,确保在操作完成之前其他线程不会看到操作的中间状态。
原子操作的实现
  1. CAS

    • CAS是由 CPU 提供的原子指令 。在硬件级别 上确保操作的原子性。不涉及上下文切换,性能高
    • 主要用途:单个变量更新
  2. posix锁机制:mutex互斥锁、spinlock自旋锁

    • 互斥锁依赖CAS,且涉及上下文切换,开销大
    • 主要用途:保护代码临界区,涉及多条cpu指令和变量的更新
  3. std::atomic

    • C++ 提供了 std::atomic 类,即原子变量 。它封装了底层的原子指令c++对原子变量的操作确保原子性

    • 基于cas实现

    • std::atomic 的内存序

    • std::atomic 还提供了内存序(memory ordering)选项,这决定了原子操作的可见性和顺序约束。例如:

    • memory_order_relaxed:不提供额外的同步或顺序保证。

    • memory_order_acquire:保证在原子操作之前的操作对当前线程可见。

    • memory_order_release:保证在原子操作之后的操作对其他线程可见。

    • memory_order_acq_rel:同时保证 acquire 和 release 语义。

    • memory_order_seq_cst:提供最严格的顺序保证。

推荐学习 https://xxetb.xetslk.com/s/p5Ibb

相关推荐
暴力求解3 小时前
Mysql数据库基础
数据库·mysql·操作系统
用户887665426639 小时前
Linux 终端入门:新手必须掌握的常用命令和基本思路
前端·操作系统
atomicmaker2 天前
操作系统 — 内存管理
操作系统·内存管理·虚拟内存·段页式
atomicmaker2 天前
操作系统 — 文件管理
操作系统·文件管理·文件系统·计算机系统
白狐_7982 天前
【XV6操作系统】Lab2(Page Table) 满分通关与答辩指南:结合408考点深度剖析
操作系统·麒麟·xv6
atomicmaker3 天前
操作系统 — 设备管理
操作系统·磁盘·设备管理·缓冲
z200509303 天前
【Linux学习】Linux中进程终止和进程等待
linux·学习·操作系统
niannian3 天前
从零开始!RuyiSDK + RISC-V 新手完整入门指南(Windows WSL2 环境)
操作系统
Bruce_kaizy4 天前
c++ linux环境编程——文件io介绍以及open 、write 、read 三剑客深度详解
linux·服务器·c++·ubuntu·操作系统·文件io
morn_venus4 天前
从 20 倍性能差距看 Linux 的 vDSO 与 vvar 机制
操作系统