Go 切片中间删除元素后,原切片仍包含被删除元素,为什么?

go 切片中间删除元素后,原切片仍包含被删除元素,为什么?

go切片的中间删除操作原理

go语言中,对切片进行操作时,会涉及到切片的底层实现原理。

例如,在下面代码中,我们创建了一个切片nums,然后使用append函数从中间删除元素,并将其放到nums6变量中。

package main

import "fmt"

func main() {
    var i = 3
    nums := []int{1, 2, 3, 4, 5, 6}
    nums6 := append(nums[:i], nums[i+2:]...)
    fmt.println(nums, nums6)
}

运行这段代码,输出的结果为:

[1 2 3 6 5 6] [1 2 3 6]

令人困惑的是,尽管我们在中间删除了元素,但nums中仍然包含了被删除的5、6元素。这是怎么回事呢?

根据go语言官方文档,append函数在追加新元素时,如果原切片的容量不足以容纳新元素,它会分配一个新的底层数组来容纳所有元素。否则,它会复用原有的底层数组。

因此,当我们对nums进行append操作时,由于添加的元素数量并没有超过nums的容量,append函数复用了原有的底层数组。这意味着nums和nums6都指向了同一个底层数组。

在新的底层数组中,nums6的元素范围是[1 2 3 6],而nums的元素范围是[1 2 3 6 5 6]。由于两个切片都指向同一个底层数组,因此当nums8修改了原有的底层数组时,nums也会被相应地修改。

由此可见,在go语言中,如果切片append操作不改变原切片的容量,那么对新的切片进行修改也会影响原切片。

以上就是Go 切片中间删除元素后,原切片仍包含被删除元素,为什么?的详细内容,更多请关注硕下网其它相关文章!