切片类型
Go 语言的切片是对数组的抽象,Go 数组的长度不可改变,在特定场景中这样的集合就不太适用,Go 提供了一种灵活的、功能强悍的内置类型切片(动态数组),与数组相比切片的长度是不固定的,可以追加元素,在追加时可能使切片的容量增大
定义切片
// 声明一个未指定大小的数组来定义切片
var identifier []type
// 使用make()函数来创建切片
var slice1 []type = make([]type, len)
也可以简写为
slice1 := make([]type, len)
// 可以指定容量,其中capacity为可选参数
make([]T, length, capacity)
切片初始化
// 直接初始化切片,[]表示是切片类型,{1,2,3}初始化值依次是1,2,3.其cap=len=3
s := []int {1,2,3}
// 初始化切片s,是数组arr的引用
s := arr[:]
// 将arr中从下标startIndex到endIndex-1 下的元素创建为一个新的切片
s := arr[startIndex:endIndex]
// 默认 endIndex 时将表示一直到arr的最后一个元素
s := arr[startIndex:]
// 默认 startIndex 时将表示从arr的第一个元素开始
s := arr[:endIndex]
// 通过切片s初始化切片s1
s1 := s[startIndex:endIndex]
// 通过内置函数make()初始化切片s, []int 标识为其元素类型为int的切片
s := make([]int, len, cap)
切片长度和容量
len() 方法 可以获取切片的长度
cap() 方法 可以获取切片的容量
一个切片在未初始化之前默认为 nil,长度为0
package main
import "fmt"
func main() {
// 空切片
var numbers []int
printSlice(numbers)
if(numbers == nil){
fmt.Printf("切片是空的”)
}
// 默认值为0的非空切片
numbers = make([]int,3,5)
printSlice(numbers)
// 切片截取
numbers = []int{0,1,2,3,4,5,6,7,8}
printSlice(numbers)
/* 打印原始切片 */
fmt.Println("numbers ==", numbers)
/* 打印子切片从索引1(包含) 到索引4(不包含)*/
printSlice("numbers[1:4] ==", numbers[1:4])
/* 默认下限为 0*/
printSlice("numbers[:3] ==", numbers[:3])
/* 默认上限为 len(s)*/
printSlice("numbers[4:] ==", numbers[4:])
}
func printSlice(x []int){
fmt.Printf("len=%d cap=%d slice=%v\n",len(x),cap(x),x)
}
切片追加和拷贝
append() 函数 可以向切片追加新元素
copy() 函数 可以拷贝切片
package main
import "fmt"
func main() {
var numbers []int
printSlice(numbers)
/* 允许追加空切片 */
numbers = append(numbers, 0)
printSlice(numbers)
/* 向切片添加一个元素 */
numbers = append(numbers, 1)
printSlice(numbers)
/* 同时添加多个元素 */
numbers = append(numbers, 2,3,4)
printSlice(numbers)
/* 创建切片 numbers1 是之前切片的两倍容量*/
numbers1 := make([]int, len(numbers), (cap(numbers))*2)
/* 拷贝 numbers 的内容到 numbers1 */
copy(numbers1,numbers)
printSlice(numbers1)
}
func printSlice(x []int){
fmt.Printf("len=%d cap=%d slice=%v\n",len(x),cap(x),x)
}