這個問題源自於需要建立一個切片位址,以便在接受 a 的函數中使用指向切片的指標。
Go 中可尋址性的鬆散定義是,你可以取得某個東西的位址,並保證這個位址指向有意義的地方。如果您在函數體中的堆疊上分配某些內容,則分配值的位址在某個時間點將不再可存取。因此,這個值是不可尋址的。
在大多數情況下,如果局部堆疊變數被返回或以其他方式提升到外部,Go 會將它們移到堆中,但在運行時這不會完成。因此,CanAddr() 僅在以下情況下返回true:
A value is addressable if it is an element of a slice, an element of an addressable array, a field of an addressable struct, or the result of dereferencing a pointer.
所聲明的類型都有一個共同點:它們保證它們所保存的內容可以從任何地方訪問,並指向內存中有意義的值。自從您使用 Reflect.MakeSlice 創建了本地切片以來,您既沒有切片元素,也沒有指針,也沒有任何其他提到的東西。不過,該切片的元素是可尋址的(因為切片的記憶體駐留在堆上)。
最簡單的解決方案可能是使用反射.New() 建立指標(播放中的完整範例):
my := &My{} // Create a slice to begin with myType := reflect.TypeOf(my) slice := reflect.MakeSlice(reflect.SliceOf(myType), 10, 10) // Create a pointer to a slice value and set it to the slice x := reflect.New(slice.Type()) x.Elem().Set(slice) collection.Find(bson.M{}).All(x.Interface())
請注意其他答案也指出的x.Interface() 。這可以防止將 x 的實際值傳遞給 All(),而不是 Reflect.Value。
以上是為什麼 `reflect.MakeSlice` 回傳一個不可尋址的 `Value`?的詳細內容。更多資訊請關注PHP中文網其他相關文章!