切片创建和初始化
slice := make([]string, 5)
slice := make([]int,3,5)
slice := []int{1,2,3}
如果只指定长度,那么切片的容量和长度相等。也可以分别指定长度和容量
// 创建一个整型切片, 长度为3个元素,容量为5个元素
slice := make([]int, 3, 5)
// 创建一个整型切片 ,长度和容量都是4个元素
slice := []int{10, 20, 30, 40}
不允许创建容量小于长度的切片,
容量小于长度的切片会在编译时报错
// 创建一个整型切片 , 使其长度大于容量
slice := make([]int, 5, 3)
Compiler Error:
len larger than cap in make([]int)
slice 常用赋值方式
1 通过index赋值
s := make([]string, 3)
s[0] = "a"
s[1] = "b"
s[2] = "c"
2 通过append赋值
相对于这些基本的操作,slices支持一些更加复杂的功能。有一个就是内置的append,可以在现有的slice对象上添加一个或多个值。注意要对返回的append对象重新赋值,以获取最新的添加了元素的slice对象。
s = append(s, "d")
s = append(s, "e", "f")
fmt.Println("apd:", s)
import "sort"
var m map[int]string
var keys []int
for k := range m {
keys = append(keys, k)
}
sort.Ints(keys)
for _, k := range keys {
fmt.Println("Key:", k, "Value:", m[k])
}
切片迭代
// 迭代每个元素,并显示值和地址
for index, value := range slice {
fmt.Printf("Value: %d Value-Addr: %X ElemAddr: %X\n",
value, &value, &slice[index])
}
Output:
Value: 10 Value-Addr: 10500168 ElemAddr: 1052E100
Value: 20 Value-Addr: 10500168 ElemAddr: 1052E104
Value: 30 Value-Addr: 10500168 ElemAddr: 1052E108
Value: 40 Value-Addr: 10500168 ElemAddr: 1052E10C
因为迭代返回的变量是一个迭代过程中根据切片依次赋值的新变量,所以value的地址总是相同的。要想获取每个元素的地址,可以使用切片变量和索引值。
如果不需要索引值,可以使用占位字符来忽略这个值,使用空白标识符(下划线)来忽略索引值
// 创建一个整型切片,长度和容量都是4个元素
slice := []int{10, 20, 30, 40}
/ /迭代每个元素,并显示其值
for _, value := range slice {
fmt.Printf("Value: %d\n", value)
}
Output:
Value: 10
Value: 20
Value: 30
Value: 40
空切片
有时,程序可能需要声明一个值为nil的切片(也称nil切片)。只要在声明时不做任何初始化,就会创建一个nil切片。
// 创建nil整型切片
var slice []int
在Go语言里,nil切片是很常见的创建切片的方法。nil切片可以用于很多标准库和内置函数。在需要描述一个不存在的切片时,nil切片会很好用。例如,函数要求返回一个切片但是发生异常的时候
// 使用make创建空的整型切片
slice := make([]int, 0)
// 使用切片字面量创建空的整型切片
slice := []int{}
空切片在底层数组包含0个元素,也没有分配任何存储空间。想表示空集合时空切片很有用,例如,数据库查询返回0个查询结果时。