Go并发计数器实现:Atomic与Mutex对比分析
时间:2026-05-14 23:49:44 374浏览 收藏
在Go并发编程中,计数器的正确实现关乎性能与可靠性:atomic.AddInt64凭借无锁、轻量、高吞吐的优势,是绝大多数场景下的首选;而sync.Mutex仅在需保障多步逻辑原子性(如条件判断、跨变量协同或副作用操作)时才不可替代——但真正容易踩坑的,不是选错工具,而是误以为用了atomic就高枕无忧,结果混用普通读写、忽略类型安全或绕过原子操作,反而引入更隐蔽的竞态问题。

Go 并发计数器该用 atomic.AddInt64 还是 sync.Mutex
绝大多数场景下,优先用 atomic.AddInt64 —— 它快、轻量、无锁,且能正确保证计数器的原子性。只有当你需要「复合操作」(比如“读+判+写”)或计数器只是更大临界区的一部分时,才考虑 sync.Mutex。
哪些操作不能靠 atomic 完成,必须上 Mutex
atomic 只保证单个操作的原子性,不提供「多步逻辑的原子封装」。一旦涉及条件判断或依赖当前值做决策,atomic 就力不从心了。
- 「如果计数器小于 100 才加 1」——
atomic.LoadInt64+atomic.AddInt64中间可能被其他 goroutine 修改,结果不可靠 - 「加 1 后立刻记录日志并触发回调」—— 日志和回调不在原子范围内,
atomic无法保护 - 多个变量需同步更新(如
count和lastUpdated)——atomic无法跨变量协调
atomic 计数器的典型写法和易错点
别直接对变量做 ++ 或 +=;所有修改必须走 atomic 函数,且类型严格匹配(int64 是默认安全类型,int 在 32 位系统上非原子)。
- 初始化必须用
int64类型:var counter int64,不是int - 读取用
atomic.LoadInt64(&counter),不是counter直接读(可能看到脏值) - 自增用
atomic.AddInt64(&counter, 1),别写counter++(竞态!) - 避免在循环里高频调用
atomic.LoadInt64做轮询判断——可能掩盖设计问题,也影响性能
性能差多少?实测常见场景下的开销差异
在纯递增场景下,atomic.AddInt64 比 sync.Mutex 快 3–5 倍,内存占用更低,且不会因锁竞争导致 goroutine 阻塞。但这个差距只在高并发(数百 goroutine 以上)、高频(每秒百万次以上)计数时才明显。
- 低频计数(如每秒几百次):两者感知不到差别,选哪个都行,但
atomic更简洁 - 争抢激烈时:
Mutex会排队、休眠、唤醒,带来调度开销;atomic是 CPU 级指令,无上下文切换 - 注意:
atomic不解决「可见性」以外的问题——比如你用atomic更新了计数,但没用atomic读,那读到的仍是旧值
真正容易被忽略的是:很多人以为用了 atomic 就万事大吉,结果在非原子路径上读写同一个变量,或者把 atomic 和普通赋值混用,反而埋下更隐蔽的竞态。
今天关于《Go并发计数器实现:Atomic与Mutex对比分析》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于的内容请关注golang学习网公众号!
相关阅读
更多>
-
505 收藏
-
503 收藏
-
502 收藏
-
502 收藏
-
502 收藏
最新阅读
更多>
-
302 收藏
-
339 收藏
-
374 收藏
-
203 收藏
-
222 收藏
-
403 收藏
-
201 收藏
-
457 收藏
-
443 收藏
-
465 收藏
-
322 收藏
-
326 收藏
课程推荐
更多>
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习