在 Go 中传递 map 给函数时,默认会创建副本,对副本的修改不影响原 map。如果需要修改原始 map,可通过指针传递。空 map 需小心处理,因为技术上是 nil 指针,传递空 map 给期望非空 map 的函数会发生错误。
Go 函数接收 map 参数时的注意事项
在 Go 中,传递 map 给函数作为参数时,存在着一些注意事项,如果不加以注意,可能会导致意想不到的结果。
副本传递
当将 map 传递给函数时,默认情况下会创建一个副本。也就是说,函数内的 map 是该参数 map 的一个副本,对副本所做的任何修改都不会影响原 map。
实战案例 1:
func modifyMap(m map[string]int) {
m["key"] = 100
}
func main() {
m := make(map[string]int)
modifyMap(m)
fmt.Println(m) // 输出:{}
}
如示例所示,modifyMap 函数对 map 做出的修改不会影响原始 map。
避免副本传递
如果需要修改原始 map,可以使用指针来传递。当传递指针时,函数内的 map 指向原始 map 的内存地址。
实战案例 2:
func modifyMap(m *map[string]int) {
(*m)["key"] = 100
}
func main() {
m := make(map[string]int)
modifyMap(&m)
fmt.Println(m) // 输出:{key: 100}
}
如示例所示,modifyMap 函数对 map 做出的修改会影响原始 map。
空 map
传递空 map 给函数时,需要小心。空 map 在技术上来说是一个 nil 指针,而并非一个有效 map。因此,如果函数期望一个非空 map,在传递空 map 时可能会发生错误。
实战案例 3:
func printMap(m map[string]int) {
for k, v := range m {
fmt.Println(k, v)
}
}
func main() {
var m map[string]int // 空 map
printMap(m) // 运行时错误:panic: runtime error: invalid memory address or nil pointer dereference
}
如示例所示,传递空 map 给函数会导致运行时错误。要解决此问题,可以对 map 进行非空检查,或提供一个默认值。
结论:
传递 map 给函数时,默认情况下会创建一个副本。
要修改原始 map,可以使用指针来传递。
小心处理空 map。
以上就是golang 函数接收 map 参数时的注意事项的详细内容。