使用接受多个参数的可变参数函数时,处理切片切片可能会带来挑战。这是一个特定的实例,其中解压一片切片可能会导致编译器错误:
考虑以下可变参数函数:
<code class="go">func unpack(args ...interface{})</code>
如果我们有一个接口切片,我们可以直接传递它到函数没有任何问题:
<code class="go">slice := []interface{}{1, 2, 3} unpack(slice) // works unpack(slice...) // also works</code>
但是,如果我们有一个接口切片,尝试传递解压版本会导致编译错误:
<code class="go">sliceOfSlices := [][]interface{}{ []interface{}{1, 2}, []interface{}{101, 102}, } unpack(sliceOfSlices) // works unpack(sliceOfSlices...) // compiler error</code>
错误消息是:
cannot use sliceOfSlices (type [][]interface {}) as type []interface {} in argument to unpack
要理解这种行为,我们需要深入研究 Go 中向可变参数传递参数的规范:
“如果最终参数是可分配的对于切片类型 []T,如果参数后跟 ....,则可以将其作为 ...T 参数的值原封不动地传递。”
在这种情况下,可变参数是 ...interface{},并且将 sliceOfSlices(类型为 [][]interface{})直接分配给 args(类型为 []interface{})是无效的。
因此,我们如何将 sliceOfSlices 的解压内容发送到 unpack() ?解决方案在于创建一个 []interface{} 类型的新切片,复制元素,然后使用 ....
<code class="go">var sliceOfSlices2 []interface{} for _, v := range sliceOfSlices { sliceOfSlices2 = append(sliceOfSlices2, v) } unpack(sliceOfSlices2...)</code>
传递它。此方法确保每个内部切片都表示为一个元素在单个切片中,使其与 ...interface{} 可变参数兼容。
以上是如何在 Go 中将切片解包到可变参数函数中?的详细内容。更多信息请关注PHP中文网其他相关文章!