2 回答
TA贡献1836条经验 获得超3个赞
Go 没有像这样的内置“强制转换”,但您可以编写一个函数来完成它。
您可以使用反射将任何类型的切片转换为 []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
}
这些函数的两个版本都按照问题中的要求工作:
myArr1 := []string {"Hey"}
myArr2 := []int {60}
unpackArray(myArr1)
unpackArray(myArr2)
笔记:
该表达式
arr.([]any)
是一个类型断言。该表达式断言接口中的具体值arr
具有类型[]any
。表达式不做任何转换。
TA贡献2019条经验 获得超9个赞
不可能直接这样做,因为这不是一回事。
any是相同的interface{},每个interface{}都是双指针(第一个是“元数据”/“类型信息”,第二个是指向原始数据的指针)。
如果你[]uint{60, 42}有一个切片,每个元素都是 8 字节(考虑 64 位)。所以,如果你强制它是[]any,每个元素现在占用 16 个字节,这会破坏一切。您可以使用unsafe.
“转换”的唯一方法是复制信息,因此,您可以创建一个新的切片,[]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 关注
- 103 浏览
添加回答
举报