在 go 中,當 key 不存在時,map 的值是零值。我在下面有一個簡短的代碼片段: 操場package mainimport ( "sync")func main() { var mm map[int]sync.Mutex var m sync.Mutex mm[1].Lock() // not work due to cannot call pointer method on mm[1] and cannot take the address of mm[1] m.Lock() // work normal}mm[1]和上面有什么區別m?我用反射來檢查,但看不出它們之間的區別。關于導致差異的任何線索?
1 回答

守候你守候我
TA貢獻1802條經驗 獲得超10個贊
問題不在于地圖的零值,而在于方法調用期間的可尋址性。
互斥鎖上的Lock方法有一個指針接收器:
func (*Mutex) Lock
給定變量,根據規范m sync.Mutex
調用帶有指針接收器的方法將自動變為:&m.Lock()
如果 x 的(類型)的方法集包含 m 并且參數列表可以分配給 m 的參數列表,則方法調用 xm() 是有效的。如果 x 是可尋址的并且 &x 的方法集包含 m,則 xm() 是 (&x).m() 的簡寫
其中重要的部分是可尋址的要求。該變量m
是可尋址的,但映射查找的返回值不是。這意味著編譯器不會嘗試調用&mm[1].Lock()
.
這些可以在您嘗試編譯示例時返回的錯誤消息中看到:
./prog.go:11:7: cannot call pointer method on mm[1] ./prog.go:11:7: cannot take the address of mm[1]
- 1 回答
- 0 關注
- 189 瀏覽
添加回答
舉報
0/150
提交
取消