06.手撕Go语言-复合数据类型之切片

切片是长度可变的数组(具有相同数据类型的数据项组成的一组长度可变的序列),切片由三部分组成:

  • 指针:指向切片第一个元素指向的数组元素的地址
  • 长度:切片元素的数量
  • 容量:切片开始到结束位置元素的数量

声明

切片声明需要指定组成元素的类型,但不需要指定存储元素的数量(长度)。在切片声明后,会被初始化为nil,表示暂不存在的切片

06.01.png

初始化

  1. 使用字面量初始化:[]type{v1, v2, …, vn}
  2. 使用字面量初始化空切片: []type{}
  3. 指定长度和容量字面量初始化:[]type{im:vm, in:vn, ilength:vlength}
  4. 使用make函数初始化

make([]type, len)/make([]type, len, cap),通过make函数创建长度为len,容量为cap的切片,len必须小于等于cap

  1. 使用数组切片操作初始化:array[start:end]/array[start:end:cap](end<=cap<=len)
06.02.png

操作

  1. 获取切片长度和容量

使用len函数可获取切片的长度,使用cap函数可获取切片容量

06.03.png
  1. 访问和修改

通过对编号对切片元素进行访问和修改,元素的编号从左到右依次为:0, 1, 2, …, n(n为切片长度-1)

06.04.png
  1. 切片: slice[start:end]用于创建一个新的切片,end <= src_cap
06.05.png

新创建切片长度和容量计算:len: end-start, cap: src_cap-start

切片共享底层数组,若某个切片元素发生变化,则数组和其他有共享元素的切片也会发生变化

06.06.png

slice[start:end:cap]可用于限制新切片的容量值, end<=cap<= src_cap

06.07.png

新创建切片长度和容量计算:len: end-start, cap: cap-start

  1. 遍历

可以通过for+len+访问方式或for-range方式对切片中元素进行遍历

06.08.png

使用for-range遍历切片,range返回两个元素分别为切片元素索引和值

  1. 增加元素

使用append对切片增加一个或多个元素并返回修改后切片,当长度在容量范围内时只增加长度,容量和底层数组不变。当长度超过容量范围则会创建一个新的底层数组并对容量进行智能运算(元素数量<1024时,约按原容量1倍增加,>1024时约按原容量0.25倍增加)

06.09.png
  1. 复制切片到另一个切片

复制元素数量为src元素数量和dest元素数量的最小值

06.10.png

使用

  1. 移除元素
06.11.png
  1. 队列

先进先出

06.12.png
  1. 堆栈

先进后出

06.13.png

多维切片

切片的元素也可以是切片类型,此时称为多维切片

06.14.png

常用包

  • sort

你可能感兴趣的:(06.手撕Go语言-复合数据类型之切片)