登录
首页 >  Golang >  Go教程

Golangatomic原子操作使用教程

时间:2026-04-09 23:07:38 323浏览 收藏

Go语言的`sync/atomic`包提供了一套高效、无锁的底层原子操作,专为`int32`、`int64`、`uint32`、`uintptr`及`unsafe.Pointer`等基础类型设计,通过`Load`、`Store`、`Add`和`CompareAndSwap`(CAS)等函数实现并发安全的读写与状态控制,在计数器、单例初始化、无锁状态机等轻量级同步场景中性能远超互斥锁;但其能力有限,仅适用于简单变量,复杂逻辑仍需依赖`mutex`或`channel`——掌握其适用边界与最佳实践,是写出高性能、无竞态Go并发程序的关键一步。

Golang如何使用 sync/atomic 实现原子操作_Golang 并发安全与性能优化

在高并发场景下,多个 goroutine 同时访问共享变量容易引发数据竞争问题。Golang 的 sync/atomic 包提供了底层的原子操作支持,能有效避免锁的开销,提升性能。相比使用 mutex 加锁,atomic 更轻量,适用于简单的共享变量读写控制。

atomic 支持的数据类型和操作

sync/atomic 主要支持对以下类型的原子操作:

  • int32、int64
  • uint32、uint64
  • uintptr
  • unsafe.Pointer(用于无锁指针操作)

常用操作函数包括:

  • atomic.LoadXXX(&val):原子读取
  • atomic.StoreXXX(&val, newVal):原子写入
  • atomic.AddXXX(&val, delta):原子增减
  • atomic.CompareAndSwapXXX(&val, old, new):CAS 操作,实现无锁并发控制的核心

典型使用场景:计数器

最常见的用途是实现并发安全的计数器。例如统计请求数、goroutine 数量等。

示例代码:

var counter int64

func increment() {
  atomic.AddInt64(&counter, 1)
}

func getCounter() int64 {
  return atomic.LoadInt64(&counter)
}

多个 goroutine 调用 increment() 不会引发竞态,且性能优于互斥锁。

CAS 实现无锁逻辑

Compare-And-Swap(CAS)是构建无锁算法的基础。可用于实现状态机、单例初始化、乐观锁等。

示例:只执行一次的初始化逻辑(类似 sync.Once):

var initialized int32

func doOnce() {
  if atomic.CompareAndSwapInt32(&initialized, 0, 1) {
    // 执行初始化逻辑
    println("initialized")
  }
}

只有第一个成功修改 initialized 值的 goroutine 会执行初始化,其余直接跳过。

性能优化建议

  • 优先使用 atomic.Value 存储复杂对象的原子读写(如配置结构体),但需保证赋值一致性
  • 避免对大结构体频繁使用原子操作,应考虑拆分或使用读写锁
  • 注意内存对齐问题,某些平台要求原子变量地址对齐到特定边界
  • 不要混合使用原子操作和非原子操作访问同一变量

atomic 虽快,但适用范围有限。仅用于简单变量同步;复杂状态管理仍推荐 mutex 或 channel。

基本上就这些。合理使用 atomic 能显著提升并发程序性能,关键在于理解其限制和适用场景。

今天关于《Golangatomic原子操作使用教程》的内容介绍就到此结束,如果有什么疑问或者建议,可以在golang学习网公众号下多多回复交流;文中若有不正之处,也希望回复留言以告知!

资料下载
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>