這是一個建立於 的文章,其中的資訊可能已經有所發展或是發生改變。
切片slice是參考型別 len()函數擷取元素的個數 cap()擷取數組的容量
1.申明方式
(1)var a []int 與數組不同的是他不申明長度
(2)s2 := make([]int, 3, 10) //元素的類型,元素的數量,元素的容量
fmt.Println(len(s2), cap(s2)) 輸出元素的數量和容量
2.講數群組轉換成切片
2 a := [10]int{}3 fmt.Println(a)4 s1 := a[:10] //取前10個元素 [5:]取 5-最後的元素 5 fmt.Println(s1)
3.slice測試
1 a := []byte{'a', 'b', 'c', 'd', 'e', 'f', 'h'}2 sa := a[2:5]3 fmt.Println(string(sa))4 sd1 := a[3:5]5 fmt.Println(string(sd1)) //看看效果
我們看到這樣的是slice_a指向Array_ori 其實是從c指向到k 我們用fmt.Println(cap(slice_a)) 結果肯定不是3
自己動手試一下下邊這個
a := []byte{'a', 'b', 'c', 'd', 'e', 'f', 'h'} sa := a[2:5]fmt.Println(string(sa)) s := sa[1:3] fmt.Println(string(s)) s2 := sa[3:5] fmt.Println(string(s2))
4.Apppend的用法
當使用append的時候,我們追加元素到切片的尾部,如果我們追加的在slice容量之中的時候我們會發現,
記憶體位址是不改變的,如果我們追加的超過容量了,記憶體位址也就改變了
1 a := make([]int, 3, 6)2 fmt.Printf("%p", a)3 a = append(a, 1, 2, 3)4 fmt.Printf("%v %p\n", a, a)5 a = append(a, 1, 2, 3)6 fmt.Printf("%v %p\n", a, a)
運行如
slice是指向底層的數組,如果多個slice指向同一個的時候,其中一個改變了,其他的都改變。試一下下邊這個
1 a := []int{1, 2, 3, 4, 5}2 s1 := a[2:5]3 s2 := a[1:3]4 fmt.Println(s1, s2)5 s1[0] = 96 fmt.Println(s1, s2)
當slice中append追加的元素超過了指向的容量,就會重新指向一個新的底層數組,
所以一個底層數組的改變,不會帶動其他的改變,
試一下下邊的代碼
1 2 a := []int{1, 2, 3, 4, 5}3 s1 := a[2:5]4 s2 := a[1:3]5 fmt.Println(s1, s2)6 s2 = append(s2, 1, 2, 2, 3, 3, 4, 5)7 s1[0] = 98 fmt.Println(s1, s2)
5.copy
這是一個拷貝的函數,下邊的代碼是從s2拷貝到s1 然後我們會看到結果是[7 8 9 4 5]
如果是copy(s2,s1) 我們看到的結果是[1 2 3]
s1 := []int{1, 2, 3, 4, 5}s2 := []int{7, 8, 9}copy(s1, s2)fmt.Println(s1)
轉載自微度網路 http://www.widuu.com/archives/08/771.html