0

0

c++怎么使用atomic原子操作_c++无锁编程基础【前沿】

冰火之心

冰火之心

发布时间:2026-03-15 14:55:02

|

272人浏览过

|

来源于php中文网

原创

std::atomic 初始化必须显式,默认构造为未初始化状态;正确方式为 std::atomic<T> var{0}; 或(C++20前)ATOMIC_VAR_INIT(0);未初始化读取将导致未定义行为。

c++怎么使用atomic原子操作_c++无锁编程基础【前沿】

atomic 初始化必须显式,不能依赖默认构造

很多初学者写 std::atomic<int> counter;</int> 就以为它初始值是 0,其实不是——std::atomic 的默认构造是“未初始化”(uninitialized),读取会触发未定义行为。真正安全的初始化只有两种方式:std::atomic<int> counter{0};</int>std::atomic<int> counter = ATOMIC_VAR_INIT(0);</int>(后者 C++20 已弃用,但兼容旧代码)。C++17 起推荐统一用花括号初始化。

常见错误现象:counter.load() 返回随机大数、程序偶发崩溃、ASan 报告“uninitialized memory read”。

  • 所有内置类型(intboolvoid*)都支持 std::atomic,但自定义类型必须满足 trivially copyable 且 sizeof
  • std::atomic_flag 是唯一保证无锁的类型,适合做自旋锁基元,但它不提供 load/store,只支持 test_and_set()clear()
  • 别用 std::atomic<t>::operator=</t> 给非 trivial 类型赋值——它不保证原子性,底层调的是非原子 memcpy

memory_order 选错会导致看似正常却出错的并发行为

不写内存序参数时,默认是 std::memory_order_seq_cst,最安全也最慢;但实际中多数场景可以降级。比如计数器递增用 memory_order_relaxed 完全没问题,而发布指针(publish-pointer pattern)必须用 memory_order_release + memory_order_acquire 配对。

典型踩坑:用 relaxed 实现引用计数释放逻辑,结果对象被提前析构;或在生产者-消费者里用 relaxed 更新标志位,消费者永远看不到 true。

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

灵机语音
灵机语音

灵机语音

下载
  • relaxed:仅保证该操作自身原子,不约束前后指令重排 → 适合计数、统计等独立变量
  • acquire/release:构成同步点,类似锁的 acquire/release 语义 → 适合状态标志、指针发布
  • seq_cst:全局顺序一致,性能开销最大 → 仅当需要跨多个原子变量建立明确先后关系时才必要

compare_exchange_weak 和 compare_exchange_strong 的区别不只是“失败概率”

compare_exchange_weak 在某些平台(尤其是 ARM、LL/SC 架构)可能伪失败(spuriously fail),即当前值等于 expected 却返回 false;strong 版本则不会。但这不是“weak 更差”,而是 weak 更轻量——它允许编译器生成更紧凑的汇编,尤其在循环中配合 while 使用时性能更好。

使用场景几乎总是:用 weak 写循环 CAS,用 strong 做单次尝试(比如实现 try_lock)。

  • 正确写法:
    while (!counter.compare_exchange_weak(expected, desired)) { /* expected 自动更新为当前值 */ }
  • 别把 expected 声明为 const —— 它会被函数内部修改
  • 在 x86 上两者汇编几乎一样,但在 ARM 上 weak 可能省掉一条 barrier 指令

无锁结构里不能直接 delete 动态对象

这是最隐蔽也最致命的问题:一个线程刚 delete 掉节点,另一个线程还在通过原子指针访问它,就产生 use-after-free。标准解法是延迟回收(deferred reclamation),比如用 hazard pointer 或 epoch-based reclamation(EBR)。C++20 的 std::atomic<:shared_ptr>></:shared_ptr> 也不能解决这个问题——它只保 shared_ptr 本身操作原子,不保所指对象生命周期。

容易被忽略的点:即使你用 std::atomic<t></t> 管理指针,只要涉及多线程读写同一块堆内存,就必须配套内存回收机制。

  • 简单项目可先用 std::shared_ptr 包裹节点,靠引用计数延后销毁,但注意:原子操作的是指针,不是对象内容
  • 真正高性能无锁容器(如 queue、stack)必须引入 RCU 或 EBR,否则只是“无锁接口,有锁语义”
  • Clang/GCC 的 -fsanitize=thread 能抓到部分 use-after-free,但无法覆盖所有无锁场景

相关文章

c++速学教程(入门到精通)
c++速学教程(入门到精通)

c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

相关标签:

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

1051

2023.08.02

int占多少字节
int占多少字节

int占4个字节,意味着一个int变量可以存储范围在-2,147,483,648到2,147,483,647之间的整数值,在某些情况下也可能是2个字节或8个字节,int是一种常用的数据类型,用于表示整数,需要根据具体情况选择合适的数据类型,以确保程序的正确性和性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

616

2024.08.29

c++怎么把double转成int
c++怎么把double转成int

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

335

2025.08.29

C++中int的含义
C++中int的含义

本专题整合了C++中int相关内容,阅读专题下面的文章了解更多详细内容。

235

2025.08.29

javascriptvoid(o)怎么解决
javascriptvoid(o)怎么解决

javascriptvoid(o)的解决办法:1、检查语法错误;2、确保正确的执行环境;3、检查其他代码的冲突;4、使用事件委托;5、使用其他绑定方式;6、检查外部资源等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

188

2023.11.23

java中void的含义
java中void的含义

本专题整合了Java中void的相关内容,阅读专题下面的文章了解更多详细内容。

134

2025.11.27

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

68

2026.03.13

Python异步编程与Asyncio高并发应用实践
Python异步编程与Asyncio高并发应用实践

本专题围绕 Python 异步编程模型展开,深入讲解 Asyncio 框架的核心原理与应用实践。内容包括事件循环机制、协程任务调度、异步 IO 处理以及并发任务管理策略。通过构建高并发网络请求与异步数据处理案例,帮助开发者掌握 Python 在高并发场景中的高效开发方法,并提升系统资源利用率与整体运行性能。

108

2026.03.12

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

324

2026.03.11

热门下载

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

精品课程

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

共94课时 | 11.3万人学习

C 教程
C 教程

共75课时 | 5.4万人学习

C++教程
C++教程

共115课时 | 21.9万人学习

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

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