golang slice学习

1. slice的结构

type slice struct {
      index  *interface  //指向首元素的指针
      len    int         //长度
      cap    int         //容量
}
slice是类型

slice类型声明后类似于:
var arr slice 而非 var arr *slice
append时,如果超过cap容量,会重新分配空间.
新空间的指针会被保存在index中,slice本身的指针不变.
举个栗子🌰:

func F() {
   intArr := make([]int, 1)
   fmt.Println(&intArr[0], len(intArr), cap(intArr))
   defer f(intArr)
   intArr = append(intArr, 1)
   fmt.Println(&intArr[0], len(intArr), cap(intArr))
   return
}

func f(intArr []int) {
   fmt.Println(&intArr[0], len(intArr), cap(intArr))
}

//结果
0xc42000d2d0 1 1
0xc42000d300 2 2
0xc42000d2d0 1 1
  • 在defer中,保存了一个副本,拷贝了intArr的值,
    在后面append中,因为容量(cap)不够,给intArr的index重新分配了空间,
    因为defer中保存的是intArr的值,所以defer打印出来的是原来的slice值
func F1() {
   intArr := make([]int, 1)
   fmt.Println(&intArr[0], len(intArr), cap(intArr))
   defer f1(&intArr)
   intArr = append(intArr, 1)
   fmt.Println(&intArr[0], len(intArr), cap(intArr))
   return
}

func f1(ia *[]int) {
   intArr := *ia
   fmt.Println(&intArr[0], len(intArr), cap(intArr))
}

//结果
0xc42000d2d0 1 1
0xc42000d300 2 2
0xc42000d300 2 2
  • 在defer中,保存了一个副本,拷贝了intArr的指针,
    在后面append中,因为容量(cap)不够,给intArr的index重新分配了空间,
    因为defer中保存的是intArr的指针,所以打印出来的是新的的slice值

2. slice的扩容

func F() {
     intArr := make([]int, 0, 0)

     intArr = append(intArr, 1)
     fmt.Println(&intArr[0], len(intArr), cap(intArr))

     intArr = append(intArr, 2)
     fmt.Println(&intArr[0], len(intArr), cap(intArr))

     intArr = append(intArr, 3)
     fmt.Println(&intArr[0], len(intArr), cap(intArr))

     intArr = append(intArr, 4)
     fmt.Println(&intArr[0], len(intArr), cap(intArr))
     return
}

//结果
0xc42000d2d0 1 1
0xc42000d300 2 2
0xc4200cc660 3 4
0xc4200cc660 4 4

在对slice进行append等操作时,可能会造成slice的自动扩容。其扩容时的大小增长规则是:

  • 如果新的大小是当前大小2倍以上,则大小增长为新大小
  • 否则循环以下操作:如果当前大小小于1024,按每次2倍增长,否则每次按当前大小1/4增长。直到增长的大小超过或等于新大小。
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 出处---Go编程语言 欢迎来到 Go 编程语言指南。本指南涵盖了该语言的大部分重要特性 Go 语言的交互式简介,...
    Tuberose阅读 18,650评论 1 46
  • 切片是 Go 中的一种基本的数据结构,使用这种结构可以用来管理数据集合。切片的设计想法是由动态数组概念而来,为了开...
    一缕殇流化隐半边冰霜阅读 13,870评论 21 55
  • Go语言做Web编程非常方便,并且在开发效率和程序运行效率方面都非常优秀。相比于Java,其最大的优势就是简便易用...
    暗黑破坏球嘿哈阅读 12,946评论 6 66
  • 双重人格 [shuāng chóng rén gé] 心理学术语 双重人格具体指一个人具有两个相对独特的并相互分开...
    精神灿烂阅读 6,621评论 0 1
  • 第八章 我死了怪不得,村里人,见到我都要冲我吐唾沫,用石头扔我。也许,我出生的当天就已经杀了人也说不定。 不过我...
    沈睿文阅读 3,077评论 2 4

友情链接更多精彩内容