atomic提供高效无锁同步,适用于计数器、状态标志等场景;通过Load、Store、Add和CAS等操作实现并发安全,如原子增减和单例模式初始化,避免数据竞争且性能优于互斥锁。

在高并发编程中,多个goroutine同时访问共享变量容易引发数据竞争问题。Golang的sync/atomic包提供了原子操作,能有效避免锁的开销,提升性能。合理使用atomic可以实现轻量级的同步控制。
原子操作保证一组操作在执行过程中不会被其他goroutine中断。atomic包支持对int32、int64、uint32、uint64、uintptr和unsafe.Pointer等类型的值进行读取、写入、增加、比较并交换等操作。这些操作由底层硬件直接支持,效率高于互斥锁。
常见场景包括计数器、状态标志、单例初始化等不需要复杂逻辑的共享变量操作。例如,一个服务需要统计请求数,使用atomic.AddInt64比加锁更高效。
atomic包中最常用的几个函数包括Load、Store、Add、Swap和CompareAndSwap(简称CAS)。
立即学习“go语言免费学习笔记(深入)”;
var counter int64
go func() {
for i := 0; i < 1000; i++ {
atomic.AddInt64(&counter, 1)
}
}()
// 主线程等待后读取最终结果
time.Sleep(time.Second)
fmt.Println("Counter:", atomic.LoadInt64(&counter))
通过atomic.CompareAndSwapPointer可以实现无锁的单例初始化,避免重复创建对象。
定义一个指针和状态标识,利用CAS判断是否已初始化实例。只有第一个成功的goroutine会真正创建对象,其余直接返回已有实例。
示例:var instance *Service
var initialized uintptr
type Service struct{}
func GetService() *Service {
if atomic.LoadUintptr(&initialized) == 1 {
return instance
}
// 尝试设置初始化状态
if atomic.CompareAndSwapUintptr(&initialized, 0, 1) {
instance = &Service{}
}
return instance
}
基本上就这些。atomic适合简单共享状态的管理,不适用于复杂临界区逻辑。掌握Load、Store、Add和CAS就能解决大多数轻量同步需求。注意变量地址不能复制,且必须对齐。合理使用能显著提升并发性能。
以上就是如何在Golang中使用atomic原子操作_Golang atomic原子操作实践的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号