Golang学习笔记——Slice
切片和數(shù)組很類似,甚至你可以理解成數(shù)組的子集。但是`切片有一個數(shù)組所沒有的特點,那就是切片的長度是可變的`。
嚴(yán)格地講,切片有`容量(capacity)`和`長度(length)`兩個屬性。
首先我們來看一下切片的定義。切片有兩種定義方式,一種是先聲明一個變量是切片,然后使用內(nèi)置函數(shù)make去初始化這個切片。另外一種是通過取數(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,這個時候x的容量是5,長度也是5。然后使用make函數(shù)定義了切片y,這個時候y的容量是10,長度是5。然后我們再分別為切片x和y的元素賦值,最后輸出。
所以使用make函數(shù)定義切片的時候,有`兩種方式`,一種`只指定長度,這個時候切片的長度和容量是相同的`。另外一種是`同時指定切片長度和容量`。雖然切片的容量可以大于長度,但是`賦值的時候要注意最大的索引仍然是len(x)-1`。否則會報索引超出邊界錯誤。
另外一種是通過數(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,那么等價于從索引0開始;如果省略了high_index,則默認(rèn)high_index等于len(arr1),即切片長度。
這里為了體現(xiàn)切片的長度可以變化,我們看一下下面的例子:
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,長度為5的切片,然后為前面的5個元素賦值。然后輸出結(jié)果。然后我們再使用Go內(nèi)置方法append來為arr1追加四個元素,這個時候再看一下arr1的容量和長度以及切片元素,我們發(fā)現(xiàn)切片的長度確實變了。
另外我們再用`append`方法給arr1多追加幾個元素,試圖超過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的長度變?yōu)?1,因為元素個數(shù)現(xiàn)在為11個。另外我們發(fā)現(xiàn)arr1的容量也變了,變?yōu)樵瓉淼膬杀丁_@是因為`Go在默認(rèn)的情況下,如果追加的元素超過了容量大小,Go會自動地重新為切片分配容量,容量大小為原來的兩倍`。
上面我們介紹了,可以`使用append函數(shù)給切片增加元素`,現(xiàn)在我們再來介紹一個`copy函數(shù)用來從一個切片拷貝元素到另一個切片`。
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,因為slice2的長度為5,所以最多拷貝5個元素。
總結(jié)一下,數(shù)組和切片的區(qū)別就在于`[]`里面是否有數(shù)字或者`...`。因為數(shù)值長度是固定的,而切片是可變的。
轉(zhuǎn)載于:https://www.cnblogs.com/cuibin/p/6752328.html
總結(jié)
以上是生活随笔為你收集整理的Golang学习笔记——Slice的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: golang sync WaitGrou
- 下一篇: 删除 Ceph 的image报rbd: