1. 问题描述
众所周知,在 golang 中,我们可以将任意类型的变量赋值给 interface{}
,通常大家会下意识写出类似代码:
var slice []int = []int{1, 2, 3}
var sliceI []interface{} = slice
可编译后报错:
cannot use slice (type []int) as type []interface {} in assignment
于是大家会有这样的疑问:既然我可以将任意类型的变量赋值给 interface{}
,为什么就不能把任意类型的切片赋值给 []interface{}
?
2. 问题的原因
首先需要明白,[]interface{}
不是接口,而是一个切片,其元素类型为 interface{}
,即该切片中的元素实际可为任意类型。
其次,[]MyType
切片与 []interface{}
切片的内存布局是完全不同的:
- 每个
interface{}
接口占用两个字(一个字表示所包含内容的类型,另一个字表示所包含的数据或指向数据的指针),于是长度为N
的[]interface{}
切片,由N * 2
个字长的数据块支持; - 而同等长度的
[]MyType
切片,其数据块的长度为N * sizeof(MyType)
个字。
由此而知,两者的数据结构不一致,便无法赋值了。
3. 如何解决?
创建等长的 []interface{}
切片,并逐一赋值。代码如下:
package main
import "fmt"
func main() {
slice := []int{1, 2, 3}
sliceI := make([]interface{}, len(slice))
for i, val := range slice {
sliceI[i] = val
}
fmt.Println(sliceI)
}
参考:golang wiki