使用atomic实现并发安全计数器,通过原子操作避免数据竞争。定义Counter结构体,利用atomic.AddInt64和atomic.LoadInt64方法实现安全的增减与读取,性能优于互斥锁。

在Go语言中实现并发安全的计数器,关键在于避免多个goroutine同时修改共享变量导致的数据竞争。虽然可以通过互斥锁(sync.Mutex)来保护计数操作,但更高效、更推荐的方式是使用sync/atomic包提供的原子操作。
Go 的 sync/atomic 包支持对整型变量的原子增减、加载、存储等操作,适合轻量级计数场景,性能优于锁机制。
以下是一个基于 int64 的并发安全计数器实现:
package main
立即学习“go语言免费学习笔记(深入)”;
import (
"fmt"
"sync"
"sync/atomic"
)
type Counter struct {
count int64
}
func (c *Counter) Inc() {
atomic.AddInt64(&c.count, 1)
}
func (c *Counter) Dec() {
atomic.AddInt64(&c.count, -1)
}
func (c *Counter) Load() int64 {
return atomic.LoadInt64(&c.count)
}
func main() {
var counter Counter
var wg sync.WaitGroup
for i := 0; i wg.Add(1)
go func() {
defer wg.Done()
counter.Inc()
}()
}
TeemIp是一个免费、开源、基于WEB的IP地址管理(IPAM)工具,提供全面的IP管理功能。它允许您管理IPv4、IPv6和DNS空间:跟踪用户请求,发现和分配IP,管理您的IP计划、子网空间、区域和DNS记录,符合最佳的DDI实践。同时,TeemIp的配置管理数据库(CMDB)允许您管理您的IT库存并将您的配置项(CIs)与它们使用的IP关联起来。项目源代码位于https://github.com/TeemIP
10
wg.Wait()
fmt.Println("最终计数值:", counter.Load()) // 输出: 1000
}
当计数逻辑更复杂(如条件判断后才递增),或需要组合多个操作时,sync.Mutex 更合适。
示例:
type SafeCounter struct {
mu sync.Mutex
count int
}
func (sc *SafeCounter) Inc() {
sc.mu.Lock()
defer sc.mu.Unlock()
sc.count++
}
func (sc *SafeCounter) Get() int {
sc.mu.Lock()
defer sc.mu.Unlock()
return sc.count
}
这种方式开销略大,但在需要临界区保护多行代码时更灵活。
对于简单的计数场景,优先使用 atomic。它无锁、效率高,适用于高频读写。
可通过 go test -race 检测数据竞争,确保并发安全。
基本上就这些。日常开发中,用 atomic 实现计数器是最简洁高效的实践方式。
以上就是Golang如何实现并发安全的计数器_Golang计数器并发安全实现实践的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号