在go中的unsafe.SliceData函数的文档中,它说:
SliceData returns a pointer to the underlying array of the argument slice. If cap(slice) > 0, SliceData returns &slice[:1][0].
返回 &slice[:1][0]
而不是 &slice[0]
背后的逻辑是什么?据我所知(并且我的测试证实),两者都会返回相同的地址。 Go 开发者选择使用前者而不是后者有什么具体原因吗?&slice[:1][0]
而不是 &slice[0]
背后的逻辑是什么?据我所知(并且我的测试证实),两者都会返回相同的地址。 Go 开发者选择使用前者而不是后者有什么具体原因吗?
切片可能具有正容量(cap(slice) > 0
),但同时可能具有 0
长度。像 slice[0]
slice[:1]
那样对其进行切片,这将产生长度为 1
的切片,并且您可以像 result[0]
切片可能具有正容量(cap(slice) > 0
),但同时可能具有 0
长度。像 slice[0]
一样对其进行索引会导致运行时恐慌。
如果切片具有正容量,您可以像
那样对结果进行索引,而不会导致运行时恐慌。例如:
slice := make([]int, 0, 5) fmt.Println(&slice[0])这会导致:🎜
panic: runtime error: index out of range [0] with length 0🎜但这有效:🎜
fmt.Println(&slice[:1][0])
以上是切片与Go中的切片的详细内容。更多信息请关注PHP中文网其他相关文章!