首頁  >  文章  >  後端開發  >  為什麼 `reflect.MakeSlice` 回傳一個不可尋址的 `Value`?

為什麼 `reflect.MakeSlice` 回傳一個不可尋址的 `Value`?

Barbara Streisand
Barbara Streisand原創
2024-11-08 05:36:01984瀏覽

Why does `reflect.MakeSlice` return an un-addressable `Value`?

為什麼 golang Reflect.MakeSlice 回傳一個不可尋址的值?

這個問題源自於需要建立一個切片位址,以便在接受 a 的函數中使用指向切片的指標。

為什麼 Reflect.MakeSlice 回傳一個不可尋址的值?

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中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn