Golang中进行reslice时的注意事项

本文深入探讨了Go语言中切片(slice)的使用及append函数的行为。通过具体示例,解析了当新切片的长度等于其容量时,append操作如何影响原切片;以及当新切片容量改变时,其行为结果不再反映到原切片的原理。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

先看下面代码:

package main

import "fmt"

func main() {
	slice := []int{0, 1, 2, 3, 4, 5, 6, 7, 8}
	fmt.Println(slice, len(slice), cap(slice)) //[0 1 2 3 4 5 6 7 8] 9 9
	newSlice := slice[6:8]
	fmt.Println(newSlice, len(newSlice), cap(newSlice)) //[6 7] 2 3
	
	//向newSlice中添加一个元素,注意此时,刚好len(newSlice) == cap(newSlice)
	newSlice = append(newSlice, 111)
	fmt.Println(slice, len(slice), cap(slice))          //[0 1 2 3 4 5 6 7 111] 9 9
	fmt.Println(newSlice, len(newSlice), cap(newSlice)) //[6 7 111] 3 3

	//再向newSlice中添加一个元素,注意此时,
	//刚好向后扩展newSlice时,已经超过了原slice的cap,超过的部分,不会反映到原slice
	newSlice = append(newSlice, 222)
	fmt.Println(slice, len(slice), cap(slice))   //[0 1 2 3 4 5 6 7 111] 9 9
	fmt.Println(newSlice, len(newSlice), cap(newSlice))  //[6 7 111 222] 4 6
}

  

然后再看这么一个代码:

package main

import "fmt"

func main() {
	slice := []int{0, 1, 2, 3, 4, 5, 6, 7, 8}
	fmt.Println(slice, len(slice), cap(slice)) //[0 1 2 3 4 5 6 7 8] 9 9
	newSlice := slice[6:8]
	fmt.Println(newSlice, len(newSlice), cap(newSlice)) //[6 7] 2 3

	//向newSlice中添加两个元素,注意此时,newSlice的len会变成4,超过了他的cap(3)
	//所以会在底层新创建一个数组来保存,所以,对newSlice的操作不会反映到原slice
	newSlice = append(newSlice, 111, 222)
	fmt.Println(slice, len(slice), cap(slice))          //[0 1 2 3 4 5 6 7 8] 9 9
	fmt.Println(newSlice, len(newSlice), cap(newSlice)) //[6 7 111 222] 4 6
}

  

综上所述:当我们调用append向一个新的slice添加元素时:

  如果新的slice在append之后,新slice的cap没有改变(即新slice的len仍小于新slice的cap),那么,至少在cap改变之前,append的行为结果都会反映到原slice

  如果新的slice在append之后,新slice的cap改变了,那么,新的slice就拥有了自己的底层数组,所以,append的行为结果不会反映到原slice,但是cap没有改变之前,仍会反映到原slice,只是在cap改变的之后,才不会反映到slice

转载于:https://www.cnblogs.com/-beyond/p/8607888.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值