0

0

如何在Golang中实现无锁数据结构 Go语言CAS操作与性能对比

P粉602998670

P粉602998670

发布时间:2026-03-16 18:43:31

|

917人浏览过

|

来源于php中文网

原创

Go 的 atomic.CompareAndSwap 系列函数本身安全,踩坑主因是内存顺序错误和数据竞争:须统一用 atomic.Load/Store 访问变量,CompareAndSwapPointer 要类型严格匹配且防 ABA,atomic.Value 更适合整值替换场景,无锁队列失败后应 nanosleep 或降级 mutex,Go 官方不推无锁因 GC 和正确性成本过高。

如何在golang中实现无锁数据结构 go语言cas操作与性能对比

Go 的 atomic.CompareAndSwap 怎么用才不踩坑

直接说结论:Go 的 atomic.CompareAndSwap 系列函数(如 CompareAndSwapInt32CompareAndSwapPointer)本身是安全的,但「用它拼无锁结构」时,90% 的问题出在内存顺序和数据竞争上,不是函数本身错。

常见错误现象:CompareAndSwapInt32 返回 true 却没生效、多 goroutine 下计数器偶尔跳变、链表节点“消失”——这些基本都不是 CAS 失败,而是读写重排或未同步的非原子字段访问导致的。

  • 必须用 atomic.Load* / atomic.Store* 读写同一变量,不能混用普通赋值(比如对 int32 字段直接 x = 1
  • CompareAndSwapPointer 要求指针类型严格匹配,传 *Node 却用 unsafe.Pointer(&node) 再转回来,若中间有逃逸或 GC 移动,可能崩溃
  • 没有“带版本号的 CAS”,无法天然防 ABA;如果复用内存地址(比如从 sync.Pool 拿节点),得自己加 tag 字段或用 atomic.Value 配合指针

atomic.Value 实现无锁配置更新为什么比手写 CAS 更稳

atomic.Value 不是 CAS,它是基于底层 unsafe.Pointer 的原子载入/存储封装,屏蔽了内存序细节,适合「整块替换」场景,比如热更新配置、切换状态机实例。

使用场景:服务运行中动态替换 map[string]string 配置、切换 TLS 证书、更新路由表 —— 这些都不需要细粒度修改,只要“换一整个值”。

立即学习go语言免费学习笔记(深入)”;

  • 写入必须用 Store,读取必须用 Load,不能把 Load() 结果强制转成可变类型再改(比如 v.Load().(map[string]string)["k"] = "v"
  • 性能上,atomic.Value 首次 Store 有少量反射开销,之后纯指针操作,比反复 CompareAndSwapPointer 更轻量
  • 不支持“条件更新”,没法实现“仅当旧值为 X 时才存 Y”,这种必须回退到 atomic.CompareAndSwapPointer

无锁队列里 CompareAndSwap 失败后该忙等还是 yield

在实现 LockFreeQueue 时,CAS 失败是常态。关键不是“要不要重试”,而是“怎么重试才不伤性能”。

知我AI
知我AI

一款多端AI知识助理,通过一键生成播客/视频/文档/网页文章摘要、思维导图,提高个人知识获取效率;自动存储知识,通过与知识库聊天,提高知识利用效率。

下载

常见错误现象:CPU 占用飙到 100%,goroutine 几乎不调度,延迟毛刺严重——这往往是因为在 tight loop 里空转调 CompareAndSwap,没给 runtime 让出机会。

  • 简单场景(如低争用计数器)可直接 for 循环重试,Go 的 runtime.osyield() 不暴露,但 runtime.Gosched() 开销太大,一般不用
  • 高争用结构(如生产者消费者队列)建议失败后 runtime.nanosleep(1)(需 import "runtime"),或更稳妥地:失败几次后 fallback 到 mutex,避免恶性自旋
  • 注意:Go 1.19+ 的 atomic 包已内联优化,但 CompareAndSwap 本身不保证指令屏障外的逻辑可见性,别指望它“顺便”刷缓存

为什么 Go 官方不推无锁容器,而 sync.Map 也不是无锁的

sync.Map 是分段锁 + 延迟初始化 + read map 快路径,它压根没用 atomic.CompareAndSwap 做核心逻辑,读多写少时靠 atomic.LoadUintptr 判断是否 dirty,写时才上锁。

原因很实际:Go 的 GC 和调度模型让纯无锁结构收益受限。比如无锁链表要管理内存生命周期,但 Go 没有可靠的 defer free 或 hazard pointer,过早回收节点就会 crash。

  • 标准库刻意回避无锁,因为正确性成本远高于性能收益;多数业务瓶颈不在 CAS,而在序列化、网络、GC 停顿
  • 第三方库如 gofork/atomicuber-go/atomic 提供了 atomic.Bool 等封装,本质仍是底层 atomic,没解决根本复杂度
  • 真正值得投入无锁的场景极少:高频 ticker 更新共享状态、极低延迟的金融行情转发、内核态 bypass 的用户态协议栈

无锁最难的从来不是写 CAS,而是定义清楚“什么算成功”“谁负责清理”“失败后状态是否可恢复”——这些没法靠函数签名约束,只能靠设计时想透。

相关文章

数码产品性能查询
数码产品性能查询

该软件包括了市面上所有手机CPU,手机跑分情况,电脑CPU,电脑产品信息等等,方便需要大家查阅数码产品最新情况,了解产品特性,能够进行对比选择最具性价比的商品。

下载

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

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

WorkBuddy
WorkBuddy

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
golang如何定义变量
golang如何定义变量

golang定义变量的方法:1、声明变量并赋予初始值“var age int =值”;2、声明变量但不赋初始值“var age int”;3、使用短变量声明“age :=值”等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

211

2024.02.23

golang有哪些数据转换方法
golang有哪些数据转换方法

golang数据转换方法:1、类型转换操作符;2、类型断言;3、字符串和数字之间的转换;4、JSON序列化和反序列化;5、使用标准库进行数据转换;6、使用第三方库进行数据转换;7、自定义数据转换函数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

247

2024.02.23

golang常用库有哪些
golang常用库有哪些

golang常用库有:1、标准库;2、字符串处理库;3、网络库;4、加密库;5、压缩库;6、xml和json解析库;7、日期和时间库;8、数据库操作库;9、文件操作库;10、图像处理库。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

357

2024.02.23

golang和python的区别是什么
golang和python的区别是什么

golang和python的区别是:1、golang是一种编译型语言,而python是一种解释型语言;2、golang天生支持并发编程,而python对并发与并行的支持相对较弱等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

214

2024.03.05

golang是免费的吗
golang是免费的吗

golang是免费的。golang是google开发的一种静态强类型、编译型、并发型,并具有垃圾回收功能的开源编程语言,采用bsd开源协议。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

410

2024.05.21

golang结构体相关大全
golang结构体相关大全

本专题整合了golang结构体相关大全,想了解更多内容,请阅读专题下面的文章。

510

2025.06.09

golang相关判断方法
golang相关判断方法

本专题整合了golang相关判断方法,想了解更详细的相关内容,请阅读下面的文章。

201

2025.06.10

golang数组使用方法
golang数组使用方法

本专题整合了golang数组用法,想了解更多的相关内容,请阅读专题下面的文章。

1539

2025.06.17

chatgpt使用指南
chatgpt使用指南

本专题整合了chatgpt使用教程、新手使用说明等等相关内容,阅读专题下面的文章了解更多详细内容。

0

2026.03.16

热门下载

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

精品课程

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

共32课时 | 6.3万人学习

Go语言实战之 GraphQL
Go语言实战之 GraphQL

共10课时 | 0.9万人学习

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

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