這是一個建立於 的文章,其中的資訊可能已經有所發展或是發生改變。
array
數組聲明--var arr [10]int,array由[n]<type>定義。n表示數組大小,type表示數群組類型
聲明且初始化--arr := [3]int{1,2,3}或者不寫大小var arr := [...]int{1,2,3}或者var arr = [3]int{1,2,3},如果不寫大小可以用三個點來表示,go會自動識別,var arr[3]int預設是初始化為0。
ps:記住:=和=之間的區別,如果是:=不需要var,如果是=需要var
二維數組初始化a := [2][2]int{ [2]int{1,2}, [2]int{3,4} },a := [2][2]int{ [...]int{1,2}, [...]int{3,4} },a := [2][2]int{ {1,2}, {3,4} }預設裡面的類型就是int
數組同樣是實值型別的:將一個數組賦值給另一個數組,會複製所有的元素。尤其是當向函數內傳遞一個數組的時候,它會獲得一個數組的副本,而不是數組的指標。
slice
slice 與array 接近,但是在新的元素加入的時候可以增加長度。slice 總是指向底層的一個array。slice 是一個指向array 的指標,這是其與array 不同的地方;slice 是參考型別, 這意味著當賦值某個slice 到另外一個變數,兩個引用會指向同一個array。例如,如果一個函數需要一個slice 參數,在其內對slice 元素的修改也會體現在函數調用者中,這和傳遞底層的array 指標類似。
slice 總是與一個固定長度的array 成對出現。其影響slice 的容量和長度
arr := [10]int{1,2,3}slice := arr[0:5]slice1 := append(slice,4,5,6)fmt.Printf("slice1 len:%d, slice1 cap:%d\n",len(slice1),cap(slice1))
fmt.Printf("slice len:%d, slice cap:%d\n",len(slice),cap(slice))fmt.Printf("arr[0]=%d,arr[1]=%d,arr[2]=%d,arr[3]=%d,arr[6]=%d\n",arr[0],arr[1],arr[2],arr[3],arr[6])
arr[6] = 5,說明slice和slice1都指向了arr。更改slice和slice1將更改arr。
函數append 向slice s 追加零值或其他x 值,並且返回追加後的新的、與s 有相同類型的slice。如果s 沒有足夠的容量儲存追加的值,append 分配一個足夠大的、新的slice 來存放原有slice 的元素和追加的值。因此,返回的slice 可能指向不同的底層array。
也就是說當slice指向一個arr時,如果通過append增加slice的容量,如果增加的值的個數沒有超過arr的長度,slice仍舊指向arr,如果超過了arr的長度,將分配一個新的slice來存放原來的slice。
make
可以通過make來建立一個長度為n的slice--sl := make([]int,6)
map
1 package main 2 3 import "fmt" 4 5 func main() { 6 monthdays := map[string]int{ 7 "Jan": 31, "Feb": 28, "Mar": 31, 8 "Apr": 30, "May": 31, "Jun": 30, 9 "Jul": 31, "Aug": 31, "Sep": 30, 10 "Oct": 31, "Nov": 30, "Dec": 31, //<--逗號是必須的11 } 12 13 fmt.Printf("%d\n", monthdays["Dec"])14 year := 015 for month,days := range monthdays {16 fmt.Printf("month :%s\n",month)17 year += days18 } 19 fmt.Printf("Numbers of days in a year: %d\n", year)20 var value int 21 var ok bool22 value, ok = monthdays["Jan"] //value將取到值,而ok則判斷值是否真的取到23 if ok == true {24 fmt.Printf("value %d exists in map\n",value)25 } 26 }