go slice

切片创建和初始化

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个查询结果时。

go slice_第1张图片
图片发自App

你可能感兴趣的:(go slice)