Go 中的append()什么时候创建一个新的切片?
Context:
Go的append()函数用于将一个或多个元素追加到一个切片中,并且有文档记载,当原始切片的容量不足时,会创建一个新的切片。然而,对向切片添加元素的递归算法的调查表明,通过通道发送的切片在发送后似乎会被修改。
混乱:
这个观察结果与文档相矛盾,文档表明append()应该返回一个新的切片。出现这种混乱的原因是,append() 文档引用了切片数据类型,而实际实现则使用切片描述符。
解决方案:
切片描述符由以下部分组成三个组成部分:长度、容量和指向基础数据的指针。当调用append()时,它返回一个具有更新的长度和容量的新切片描述符。然而,指向底层数据的指针保持不变。
说明:
因此,虽然append()确实返回了一个新的切片描述符,但实际数据仍然是在新旧切片之间共享。这是因为底层数据存储在切片描述符指向的单独内存位置中。
示例:
以下代码说明了此行为:
<code class="go">package main import "fmt" func main() { s := make([]int, 0, 5) s = append(s, []int{1, 2, 3, 4}...) a := append(s, 5) fmt.Println(a) b := append(s, 6) fmt.Println(b) fmt.Println(a) }</code>
输出显示两个修改后的切片 a 和 b 与原始切片 s 共享相同的基础数据,即使它们具有不同的长度和容量。
以上是Go 的 `append()` 函数总是创建一个新切片吗?的详细内容。更多信息请关注PHP中文网其他相关文章!