2 回答

TA貢獻1836條經(jīng)驗 獲得超3個贊
Go 沒有像這樣的內(nèi)置“強制轉(zhuǎn)換”,但您可以編寫一個函數(shù)來完成它。
您可以使用反射將任何類型的切片轉(zhuǎn)換為 []any:
func unpackArray(s any) []any {
v := reflect.ValueOf(s)
r := make([]any, v.Len())
for i := 0; i < v.Len(); i++ {
r[i] = v.Index(i).Interface()
}
return r
}
您還可以在 Go 1.18 或更高版本中使用泛型:
func unpackArray[S ~[]E, E any](s S) []any {
r := make([]any, len(s))
for i, e := range s {
r[i] = e
}
return r
}
這些函數(shù)的兩個版本都按照問題中的要求工作:
myArr1 := []string {"Hey"}
myArr2 := []int {60}
unpackArray(myArr1)
unpackArray(myArr2)
筆記:
該表達式
arr.([]any)
是一個類型斷言。該表達式斷言接口中的具體值arr
具有類型[]any
。表達式不做任何轉(zhuǎn)換。

TA貢獻2019條經(jīng)驗 獲得超9個贊
不可能直接這樣做,因為這不是一回事。
any是相同的interface{},每個interface{}都是雙指針(第一個是“元數(shù)據(jù)”/“類型信息”,第二個是指向原始數(shù)據(jù)的指針)。
如果你[]uint{60, 42}有一個切片,每個元素都是 8 字節(jié)(考慮 64 位)。所以,如果你強制它是[]any,每個元素現(xiàn)在占用 16 個字節(jié),這會破壞一切。您可以使用unsafe.
“轉(zhuǎn)換”的唯一方法是復制信息,因此,您可以創(chuàng)建一個新的切片,[]any然后將每個值附加到該新切片中。
復制的一個例子是:
// You can edit this code!
package main
func unpackArray[T any](arr any) (r []any) {
o := arr.([]T)
r = make([]any, len(o))
for i, v := range o {
r[i] = any(v)
}
return r
}
func main() {
myArr1 := []string{"Hey"}
myArr2 := []int{60}
unpackArray[string](myArr1)
unpackArray[int](myArr2)
}
然而,這并沒有多大意義,因為您可以以另一種方式使用泛型。
- 2 回答
- 0 關注
- 128 瀏覽
添加回答
舉報