在 golang 中正确初始化 map 的方式有两种:先声明再初始化,或声明时直接赋值并初始化;若已知初始容量,可在 make 时指定大小以提升性能;由于 map 是引用类型,在函数间传递时为浅拷贝,且默认不支持并发安全访问,多个 goroutine 同时读写可能导致 panic 或数据不一致;实现并发安全的常见方法有三种:1. 使用 sync.mutex 加锁控制读写;2. 使用 sync.rwmutex 提升读多写少场景下的性能;3. 使用 sync.map(适用于键值基本不变或读多写少的场景),但其不支持遍历、获取长度及频繁更新。

在 Golang 中,
map

在 Go 中声明和初始化
map
// 方式一:先声明再初始化
myMap := make(map[string]int)
myMap["a"] = 1
// 方式二:声明同时初始化
myMap := map[string]int{
"a": 1,
"b": 2,
}建议:如果知道初始容量,可以在 make 时指定大小,避免频繁扩容影响性能:myMap := make(map[string]int, 10) // 初始容量为10
注意:
map
立即学习“go语言免费学习笔记(深入)”;
Go 的
map
map

举个例子:
m := make(map[int]int)
for i := 0; i < 100; i++ {
go func(i int) {
m[i] = i * i
}(i)
}这段代码运行时很可能会触发 fatal error,提示“concurrent map writes”。
有以下几种常见方案:
sync.Mutex
sync.RWMutex
sync.Map
var mu sync.Mutex m := make(map[string]int) mu.Lock() m["a"] = 1 mu.Unlock()
这种方式适合读写都比较均衡的情况,但每次读写都要加锁,效率略低。
适用于读多写少的场景:
var mu sync.RWMutex m := make(map[string]int) // 写的时候加写锁 mu.Lock() m["a"] = 1 mu.Unlock() // 读的时候加读锁 mu.RLock() fmt.Println(m["a"]) mu.RUnlock()
sync.Map
示例用法:
var sm sync.Map
sm.Store("a", 1)
value, ok := sm.Load("a")注意:
不支持遍历、不能获取长度,也不适合频繁更新的场景。sync.Map登录后复制
基本上就这些了。Golang 的 map 使用起来简单,但在并发环境下要特别小心。根据实际业务场景选择合适的同步机制,能有效避免程序崩溃或逻辑错误。
以上就是Golang的map如何使用 详解哈希表初始化与并发安全方案的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号