登录
首页 >  Golang >  Go教程

Go 共享状态并发安全:mutex、atomic 和 channel 怎么选

来源:Golang学习网专题原创

时间:2026-06-09 06:06:00 539浏览 收藏

所属专题:Go 并发治理实战

Go 鼓励通过通信共享内存,但真实业务里仍然会有本地缓存、计数器、连接状态和配置快照。选择同步工具时,要看数据语义,而不是只看哪个写起来短。

mutex 适合保护复杂状态

如果一次操作需要同时读写多个字段,mutex 最清晰。临界区要短,不要在持锁时做网络请求或慢 SQL。

atomic 适合简单数值或指针替换

计数器、开关、只读配置快照可以考虑 atomic。但 atomic 不能自动保护多个变量之间的一致性。

channel 适合所有权转移

当数据应该由单个 goroutine 顺序处理时,channel 可以让所有权更清晰,例如任务队列或事件流。

代码示例

type Counter struct {
    mu sync.Mutex
    m  map[string]int64
}

func (c *Counter) Inc(key string) {
    c.mu.Lock()
    defer c.mu.Unlock()
    c.m[key]++
}

上线检查

  • 本地运行 go test -race。
  • 持锁区域不做慢 IO。
  • 多个字段的一致性不用 atomic 硬凑。
声明:本文转载于:Golang学习网专题原创 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>