Golang学习笔记——Slice
切片和數(shù)組很類似,甚至你可以理解成數(shù)組的子集。但是`切片有一個(gè)數(shù)組所沒有的特點(diǎn),那就是切片的長(zhǎng)度是可變的`。
嚴(yán)格地講,切片有`容量(capacity)`和`長(zhǎng)度(length)`兩個(gè)屬性。
首先我們來看一下切片的定義。切片有兩種定義方式,一種是先聲明一個(gè)變量是切片,然后使用內(nèi)置函數(shù)make去初始化這個(gè)切片。另外一種是通過取數(shù)組切片來賦值。
1 package main 2 3 import ( 4 "fmt" 5 ) 6 7 func main() { 8 var x = make([]float64, 5) 9 fmt.Println("Capcity:", cap(x), "Length:", len(x)) 10 var y = make([]float64, 5, 10) 11 fmt.Println("Capcity:", cap(y), "Length:", len(y)) 12 13 for i := 0; i < len(x); i++ { 14 x[i] = float64(i) 15 } 16 fmt.Println(x) 17 18 for i := 0; i < len(y); i++ { 19 y[i] = float64(i) 20 } 21 fmt.Println(y) 22 }輸出結(jié)果為
Capcity: 5 Length: 5
Capcity: 10 Length: 5
[0 1 2 3 4]
[0 1 2 3 4]
上面我們首先用make函數(shù)定義切片x,這個(gè)時(shí)候x的容量是5,長(zhǎng)度也是5。然后使用make函數(shù)定義了切片y,這個(gè)時(shí)候y的容量是10,長(zhǎng)度是5。然后我們?cè)俜謩e為切片x和y的元素賦值,最后輸出。
所以使用make函數(shù)定義切片的時(shí)候,有`兩種方式`,一種`只指定長(zhǎng)度,這個(gè)時(shí)候切片的長(zhǎng)度和容量是相同的`。另外一種是`同時(shí)指定切片長(zhǎng)度和容量`。雖然切片的容量可以大于長(zhǎng)度,但是`賦值的時(shí)候要注意最大的索引仍然是len(x)-1`。否則會(huì)報(bào)索引超出邊界錯(cuò)誤。
另外一種是通過數(shù)組切片賦值,采用`[low_index:high_index]`的方式獲取數(shù)值切片,其中切片元素`包括low_index的元素`,但是`不包括high_index的元素`。
1 package main 2 3 import ( 4 "fmt" 5 ) 6 7 func main() { 8 var arr1 = [5]int{1, 2, 3, 4, 5} 9 var s1 = arr1[2:3] 10 var s2 = arr1[:3] 11 var s3 = arr1[2:] 12 var s4 = arr1[:] 13 fmt.Println(s1) 14 fmt.Println(s2) 15 fmt.Println(s3) 16 fmt.Println(s4) 17 }輸出結(jié)果為
[3]
[1 2 3]
[3 4 5]
[1 2 3 4 5]
在上面的例子中,我們還省略了low_index或high_index。如果省略了low_index,那么等價(jià)于從索引0開始;如果省略了high_index,則默認(rèn)high_index等于len(arr1),即切片長(zhǎng)度。
這里為了體現(xiàn)切片的長(zhǎng)度可以變化,我們看一下下面的例子:
1 package main 2 3 import ( 4 "fmt" 5 ) 6 7 func main() { 8 var arr1 = make([]int, 5, 10) 9 for i := 0; i < len(arr1); i++ { 10 arr1[i] = i 11 } 12 fmt.Println(arr1) 13 14 arr1 = append(arr1, 5, 6, 7, 8) 15 fmt.Println("Capacity:", cap(arr1), "Length:", len(arr1)) 16 fmt.Println(arr1) 17 }輸出結(jié)果為
[0 1 2 3 4]
Capacity: 10 Length: 9
[0 1 2 3 4 5 6 7 8]
這里我們初始化arr1為容量10,長(zhǎng)度為5的切片,然后為前面的5個(gè)元素賦值。然后輸出結(jié)果。然后我們?cè)偈褂肎o內(nèi)置方法append來為arr1追加四個(gè)元素,這個(gè)時(shí)候再看一下arr1的容量和長(zhǎng)度以及切片元素,我們發(fā)現(xiàn)切片的長(zhǎng)度確實(shí)變了。
另外我們?cè)儆?#96;append`方法給arr1多追加幾個(gè)元素,試圖超過arr1原來定義的容量大小。
1 package main 2 3 import ( 4 "fmt" 5 ) 6 7 func main() { 8 var arr1 = make([]int, 5, 10) 9 for i := 0; i < len(arr1); i++ { 10 arr1[i] = i 11 } 12 13 arr1 = append(arr1, 5, 6, 7, 8, 9, 10) 14 fmt.Println("Capacity:", cap(arr1), "Length:", len(arr1)) 15 fmt.Println(arr1) 16 }輸出結(jié)果為
Capacity: 20 Length: 11
[0 1 2 3 4 5 6 7 8 9 10]
我們發(fā)現(xiàn)arr1的長(zhǎng)度變?yōu)?1,因?yàn)樵貍€(gè)數(shù)現(xiàn)在為11個(gè)。另外我們發(fā)現(xiàn)arr1的容量也變了,變?yōu)樵瓉淼膬杀丁_@是因?yàn)?#96;Go在默認(rèn)的情況下,如果追加的元素超過了容量大小,Go會(huì)自動(dòng)地重新為切片分配容量,容量大小為原來的兩倍`。
上面我們介紹了,可以`使用append函數(shù)給切片增加元素`,現(xiàn)在我們?cè)賮斫榻B一個(gè)`copy函數(shù)用來從一個(gè)切片拷貝元素到另一個(gè)切片`。
1 package main 2 3 import ( 4 "fmt" 5 ) 6 7 func main() { 8 slice1 := []int{1, 2, 3, 4, 5, 6} 9 slice2 := make([]int, 5, 10) 10 copy(slice2, slice1) 11 fmt.Println(slice1) 12 fmt.Println(slice2) 13 }輸出結(jié)果
[1 2 3 4 5 6]
[1 2 3 4 5]
在上面的例子中,我們將slice1的元素拷貝到slice2,因?yàn)閟lice2的長(zhǎng)度為5,所以最多拷貝5個(gè)元素。
總結(jié)一下,數(shù)組和切片的區(qū)別就在于`[]`里面是否有數(shù)字或者`...`。因?yàn)閿?shù)值長(zhǎng)度是固定的,而切片是可變的。
轉(zhuǎn)載于:https://www.cnblogs.com/cuibin/p/6752328.html
總結(jié)
以上是生活随笔為你收集整理的Golang学习笔记——Slice的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: golang sync WaitGrou
- 下一篇: 删除 Ceph 的image报rbd: