標籤:結束 Go語言 拷貝 logs 容量 [] append div printf
package main;import "fmt"func main() {//slice本身不是數組,指向底層的數組//作為變長數組的替換方案//slice是參考型別//聲明一個slice,這裡不需要指定長度var a []int;//建立一個數組var b = [10]int{1, 2, 3, 4, 5, 6, 7, 8, 9, 10};//通過數組來建立slicec := b[1:len(b)];//同上,簡寫d := b[1:];//從下標2開始,到4結束,不包括下標4的元素e := b[2:4];//從數組開始,取3個f := b[:3];//通過make建立slice//長度為3,容量為10的sliceg := make([]int, 3, 10);h := []byte{‘a‘, ‘b‘, ‘c‘, ‘d‘, ‘e‘, ‘f‘, ‘g‘};i := h[2:5];//注意這裡的索引是相對i的索引,i現在是[‘c‘, ‘d‘, ‘e‘]j := i[1:3];//注意這裡6已經超過了i的cap容量,會報錯//j := i[1:6];//在slice的尾部追加元素k := make([]int, 3, 6);fmt.Printf("%p %v\n", &k, k);k = append(k, 1, 2, 3);fmt.Printf("%p %v\n", &k, k);//這裡當追加的元素超過了slice的cap時,會重新分配地址,並把值拷貝k = append(k, 4, 5, 6);fmt.Printf("%p %v\n", &k, k);//slice是參考型別,修改某一個slice的值,其他也相應改變m := []int{1, 2, 3, 4, 5};l := m[2:5];n := m[1:4];fmt.Println(m, l, n);//改變l中的值,m,n中也相應改變l[0] = 6;fmt.Println(m, l, n);//如果當slice發生地址重新分配後,那相應改變是不生效的o := []int{1, 2, 3, 4, 5};p := o[2:5];q := o[1:4];fmt.Println(o, p, q);//在改變p元素值之前,我們讓q發生地址重新分配q = append(q, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1);//再改變p的值,這時q的值不會發生改變,因為它已經指向新的地址p[0] = 6;fmt.Println(o, p, q);//copy時以長度短的為準r := []int{1, 2, 3, 4, 5};s := []int{6, 7, 8};//這裡只會把s中的6,7,8拷貝到r中的1,2,3copy(r, s);fmt.Println(r, s);fmt.Println(a);fmt.Println(b);fmt.Println(c);fmt.Println(d);fmt.Println(e);fmt.Println(f);fmt.Println(g, len(g), cap(g));fmt.Println(string(h));fmt.Println(string(i), cap(i));fmt.Println(string(j), cap(j));}
go語言中的slice