0

0

c++的std::atomic如何实现CAS操作_c++无锁编程核心原子指令

穿越時空

穿越時空

发布时间:2025-12-12 15:50:42

|

381人浏览过

|

来源于php中文网

原创

CAS是C++无锁编程的核心,通过compare_exchange_weak/strong实现原子性条件更新,前者在循环中更高效但可能伪失败,后者保证仅值不匹配时失败,常用于无锁计数器等场景,依赖硬件指令如CMPXCHG确保原子性。

c++的std::atomic如何实现cas操作_c++无锁编程核心原子指令

在C++的无锁编程中,std::atomic 是实现线程安全操作的核心工具之一。其中最关键的操作就是CAS(Compare-and-Swap),它允许在不使用互斥锁的前提下完成原子性的条件更新,是构建无锁数据结构如无锁队列、无锁的基础。

什么是CAS操作?

CAS(Compare-and-Swap)是一种原子指令,用于判断某个内存位置的当前值是否等于预期值,如果是,则将其更新为新值;否则不做修改。这个过程是原子的,不会被其他线程打断。

std::atomic 中,CAS 通过两个成员函数实现:

  • compare_exchange_weak()
  • compare_exchange_strong()

这两个函数都遵循相同的语义:比较原子对象的当前值与期望值,若相等则写入新值,并返回 true;否则将当前值写回期望值变量,并返回 false。

立即学习C++免费学习笔记(深入)”;

compare_exchange_weak 与 compare_exchange_strong 的区别

两者功能相似,但在某些平台上(如x86以外的架构),weak 版本可能偶尔失败,即使值实际上匹配。这种“伪失败”是为了获得更高的性能,特别是在循环中使用时。

通常建议在循环中使用 compare_exchange_weak,因为它在某些架构上更高效:

std::atomic value{0};

int expected = value.load();
while (!value.compare_exchange_weak(expected, desired)) {
    // 如果失败,expected 已被更新为当前实际值
    // 可以选择重新计算 desired 或退出
}

compare_exchange_strong 保证只有在值不匹配时才失败,适合不需要循环或对失败敏感的场景。

DeepL Write
DeepL Write

DeepL推出的AI驱动的写作助手,在几秒钟内完善你的写作

下载

CAS 在无锁编程中的典型应用

利用 CAS 可以实现诸如无锁计数器、无锁链表节点插入等操作。例如,一个简单的无锁递增可以通过 CAS 实现:

void lock_free_increment(std::atomic& counter) {
    int expected = counter.load();
    int desired;
    while (true) {
        desired = expected + 1;
        if (counter.compare_exchange_weak(expected, desired)) {
            break;  // 成功更新
        }
        // 失败时,expected 被更新为当前值,继续重试
    }
}

这个模式称为“读-改-重试”循环,是无锁编程中最常见的结构。

底层实现依赖硬件原子指令

std::atomic 的 CAS 操作最终会编译成对应平台的原子汇编指令,比如:

  • x86/x64 上的 CMPXCHG 指令
  • ARM 上的 LDXR/STXRLDAXR/STLXR 指令对

这些指令由CPU提供支持,确保操作的原子性,不会被中断或与其他核心冲突。

编译器和标准库会根据类型大小和平台选择合适的原子实现方式,对于无法直接支持的类型,可能禁用原子操作或产生编译错误

基本上就这些。CAS 是 C++ 无锁编程的基石,掌握 compare_exchange_weak/strong 的使用方法和重试逻辑,是编写高效、安全并发结构的关键。

相关专题

更多
treenode的用法
treenode的用法

​在计算机编程领域,TreeNode是一种常见的数据结构,通常用于构建树形结构。在不同的编程语言中,TreeNode可能有不同的实现方式和用法,通常用于表示树的节点信息。更多关于treenode相关问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

536

2023.12.01

C++ 高效算法与数据结构
C++ 高效算法与数据结构

本专题讲解 C++ 中常用算法与数据结构的实现与优化,涵盖排序算法(快速排序、归并排序)、查找算法、图算法、动态规划、贪心算法等,并结合实际案例分析如何选择最优算法来提高程序效率。通过深入理解数据结构(链表、树、堆、哈希表等),帮助开发者提升 在复杂应用中的算法设计与性能优化能力。

17

2025.12.22

深入理解算法:高效算法与数据结构专题
深入理解算法:高效算法与数据结构专题

本专题专注于算法与数据结构的核心概念,适合想深入理解并提升编程能力的开发者。专题内容包括常见数据结构的实现与应用,如数组、链表、栈、队列、哈希表、树、图等;以及高效的排序算法、搜索算法、动态规划等经典算法。通过详细的讲解与复杂度分析,帮助开发者不仅能熟练运用这些基础知识,还能在实际编程中优化性能,提高代码的执行效率。本专题适合准备面试的开发者,也适合希望提高算法思维的编程爱好者。

24

2026.01.06

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

394

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

574

2023.08.10

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

482

2023.08.10

c++ 根号
c++ 根号

本专题整合了c++根号相关教程,阅读专题下面的文章了解更多详细内容。

25

2026.01.23

c++空格相关教程合集
c++空格相关教程合集

本专题整合了c++空格相关教程,阅读专题下面的文章了解更多详细内容。

31

2026.01.23

yy漫画官方登录入口地址合集
yy漫画官方登录入口地址合集

本专题整合了yy漫画入口相关合集,阅读专题下面的文章了解更多详细内容。

119

2026.01.23

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 4.1万人学习

Pandas 教程
Pandas 教程

共15课时 | 1.0万人学习

ASP 教程
ASP 教程

共34课时 | 4万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号