赞
踩
可变长度的数组
,其实它底层就是使用数组实现的,增加了自动扩容功能。切片(Slice)
是一个拥有相同类型元素的可变长度的序列。声明一个切片和声明一个数组类似,只要不添加长度即可
var identifier []type
切片是引用类型,可以使用make函数
来创建切片:
var slice1 []type =make([]type, len)
也可以简写为
slice1 := make([]type, len)
也可以指定容量,其中capacity为可选参数
make([]T,length,capacity)
这里len是数组的长度并且也是切片的初始长度
切片在没有赋值之前是空值
声明变量的方式创建切片
package main import "fmt" func main() { var names []string var numbers []int fmt.Printf("names: %v\n", names) fmt.Printf("numbers: %v\n", numbers) fmt.Println(names == nil) fmt.Println(numbers == nil) } //输出结果如下 names: [] numbers: [] true true
使用make函数
创建切片
package main
import "fmt"
func main() {
var a = make([]int, 2)
var b = make([]int, 3)
fmt.Printf("a: %v\n", a)
fmt.Printf("b: %v\n", b)
}
//输出结果如下
a: [0 0]
b: [0 0 0]
切片拥有自己的长度和容量,我们可以通过使用内置的len()函数
求出长度,使用内置的cap()函数
求出切片的内容。
package main import "fmt" func main() { var names = []string{"hello", "world"} var num = []int{1, 2, 3} fmt.Printf("len: %d cap: %d\n", len(names), cap(names)) fmt.Printf("len: %d cap: %d\n", len(num), cap(num)) fmt.Printf("num[2]: %v\n", num[2])//根据下标索引来获取切片的元素 fmt.Println("-----------") var a = make([]string, 2, 3) fmt.Printf("len: %d cap: %d", len(a), cap(a)) } //输出结果如下 len: 2 cap: 2 len: 3 cap: 3 num[2]: 3 ----------- len: 2 cap: 3
切片的初始化方式有很多种,可以直接初始化,也可以使用数组初始化。
package main
import "fmt"
func main() {
a := []int{1, 2, 3}
fmt.Printf("a: %v\n", a)
}
//输出结果如下
a: [1 2 3]
package main
import "fmt"
func main() {
a := [...]int{1, 2, 3}
b := a[:]
fmt.Printf("b: %v\n", b)
}
//输出结果
b: [1 2 3]
数组
,所以我们可以基于数组通过切片表达式得到切片
。low
和high
表示一个索引范围(包左不包右)
,得到切片的长度=high-low
,容量等于得到的切片的底层数组的容量。package main import "fmt" func main() { a := [...]int{1, 2, 3, 4, 5, 6, 7, 8} b := a[2:5] //下标2到5,左闭右开,不包括5 fmt.Printf("b: %v\n", b) c := a[2:] //下标2后面的所有 fmt.Printf("c: %v\n", c) d := a[:3] //下标3之前的,不包括3 fmt.Printf("d: %v\n", d) e := a[:] //取所有值 fmt.Printf("e: %v\n", e) } //输出结果如下 b: [3 4 5] c: [3 4 5 6 7 8] d: [1 2 3] e: [1 2 3 4 5 6 7 8]
一个切片在未初始化之前默认为nil,长度为0,容量为0
package main
import "fmt"
func main() {
var a []int
fmt.Println(a == nil)
fmt.Printf("len: %d,cap: %d\n", len(a), cap(a))
}
//输出结果如下
true
len: 0,cap: 0
切片的遍历和数组的遍历非常类型,可以使用for
循环索引遍历,或者for range
循环
package main import "fmt" func main() { s1 := []int{1, 2, 3, 4, 5, 6} for i := 0; i < len(s1); i++ { fmt.Printf("s1[%d]: %v\n", i, s1[i]) } } //输出结果如下 s1[0]: 1 s1[1]: 2 s1[2]: 3 s1[3]: 4 s1[4]: 5 s1[5]: 6
package main import "fmt" func main() { s1 := []int{1, 2, 3, 4, 5, 6} for i, v := range s1 { fmt.Printf("i: %v,v: %v\n", i, v) } } //输出结果如下,i是索引,v是值 i: 0,v: 1 i: 1,v: 2 i: 2,v: 3 i: 3,v: 4 i: 4,v: 5 i: 5,v: 6
append()函数
添加元素copy()函数
来拷贝切片package main import "fmt" func main() { a := []int{} a = append(a, 1) a = append(a, 2) a = append(a, 3, 4, 5) //添加多个元素 fmt.Printf("a: %v\n", a) fmt.Println("---------------------") a1 := []int{3, 4, 5} a2 := []int{1, 2} a2 = append(a2, a1...) //添加另外一个切片进去 fmt.Printf("a2: %v\n", a2) } //输出结果如下 a: [1 2 3 4 5] --------------------- a2: [1 2 3 4 5]
package main import "fmt" func main() { var s1 = []int{1, 2, 3, 4} fmt.Println("---删除之前---") fmt.Printf("s1: %v\n", s1) //删除3这个元素,它的下标索引为2 s1 = append(s1[:2], s1[3:]...) fmt.Println("---删除之后---") fmt.Printf("s1: %v\n", s1) } //执行结果如下 ---删除之前--- s1: [1 2 3 4] ---删除之后--- s1: [1 2 4]
删除元素的公式
要从切片a中删除索引为index的元素,操作方法如下
a = append(a[:index], a[index+1:]...)
package main
import "fmt"
func main() {
var s1 = []int{1, 2, 3, 4, 5}
s1[1] = 100 //索引1的值改为100
fmt.Printf("s1: %v\n", s1)
}
//输出结果如下
s1: [1 100 3 4 5]
package main import "fmt" func main() { var s1 = []int{1, 2, 3, 4, 5} var key = 2 //查找2所在的位置 for i, v := range s1 { if v == key { fmt.Printf("s1: %v\n", s1) fmt.Printf("索引为: %v\n", i) } } } //输出结果如下 s1: [1 2 3 4 5] 索引为: 1
package main
import "fmt"
func main() {
var s1 = []int{1, 2, 3, 4, 5}
var s2 = s1
s2[0] = 100
fmt.Printf("s1: %v\n", s1)
fmt.Printf("s2: %v\n", s2)
}
//输出结果如下
s1: [100 2 3 4 5]
s2: [100 2 3 4 5]
可以看到当s2的值改变的时候,s1的值也改变了,因为s2复制了s1的是他的内存地址,所以相关联都会改变
copy
方法修改则不会对源切片的值有影响package main import "fmt" func main() { var s1 = []int{1, 2, 3, 4, 5} var s2 = make([]int, 4) //需要make一个切片的类型,指定有5个元素 copy(s2, s1) //指定复制的切片 s2[0] = 100 fmt.Printf("s1: %v\n", s1) fmt.Printf("s2: %v\n", s2) } //输出结果 s1: [1 2 3 4 5] s2: [100 2 3 4 5]
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。