使用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()
}()
}
新快购物系统是集合目前网络所有购物系统为参考而开发,不管从速度还是安全我们都努力做到最好,此版虽为免费版但是功能齐全,无任何错误,特点有:专业的、全面的电子商务解决方案,使您可以轻松实现网上销售;自助式开放性的数据平台,为您提供充满个性化的设计空间;功能全面、操作简单的远程管理系统,让您在家中也可实现正常销售管理;严谨实用的全新商品数据库,便于查询搜索您的商品。
0
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号