在 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 参数时的注意事项的详细内容,更多请关注叮当号网其它相关文章!
文章来自互联网,只做分享使用。发布者:走不完的路,转转请注明出处:https://www.dingdanghao.com/article/519271.html