在 go 中,當(dāng) 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]和上面有什么區(qū)別m?我用反射來檢查,但看不出它們之間的區(qū)別。關(guān)于導(dǎo)致差異的任何線索?
1 回答

守候你守候我
TA貢獻(xiàn)1802條經(jīng)驗 獲得超10個贊
問題不在于地圖的零值,而在于方法調(diào)用期間的可尋址性。
互斥鎖上的Lock方法有一個指針接收器:
func (*Mutex) Lock
給定變量,根據(jù)規(guī)范m sync.Mutex
調(diào)用帶有指針接收器的方法將自動變?yōu)椋?code>&m.Lock()
如果 x 的(類型)的方法集包含 m 并且參數(shù)列表可以分配給 m 的參數(shù)列表,則方法調(diào)用 xm() 是有效的。如果 x 是可尋址的并且 &x 的方法集包含 m,則 xm() 是 (&x).m() 的簡寫
其中重要的部分是可尋址的要求。該變量m
是可尋址的,但映射查找的返回值不是。這意味著編譯器不會嘗試調(diào)用&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 關(guān)注
- 185 瀏覽
添加回答
舉報
0/150
提交
取消