GO 调用切片append后导致原切片数据异常,什么原理?
如图:
这个5是怎么出现的
代码:
func rangeList() {
c := [3]int{1, 2, 3}
d := []int{4, 5}
e := append(c[:], d...)
fmt.Printf("e: %p\n", &e)
fmt.Println(e)
i := 2
e1 := e[:i]
fmt.Printf("e1: %p\n", &e1)
fmt.Println(e1)
f := append(e1, e[i+1:]...)
fmt.Printf("f: %p\n", &f)
fmt.Println(f)
fmt.Printf("e: %p\n", &e)
fmt.Println(e)
}
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
e1
是从e
来的,容量是5,所以append(e1, e[i+1:])
不需要分配新的内存空间,直接修改了底层的内存了。所以最终e
于f
的相同。为什么e1
不是,因为受长度限制,实际上它们指向的内存是同一个,你可以试试fmt.Println(e1[:5])
打印看看。https://www.jianshu.com/p/354... 有详解
问题的关键在于通过切片创建切片后 cap大小的问题