數組
數組的概念之前在c裏面就有所以並不會很陌生,但是仍然有些區別。
數組是內置(build-in)類型,是一組同類型數據的集合,它是值類型,通過從0開始的下標索引訪問元素值。
在c++裏面我們使用數組在傳參的時候傳遞的都是指針,但是在go裏面對數組進行賦值或者是穿參都是傳值的行爲。所以效率會有所降低。數組的長度也是其類型的一部分,通過內置函數len(array)獲取其長度。
定義的方法
var 變量名[len] type
var a[5] int // 3個整數的數組
var a[5] string //3個字符串的數組
//不指定長度的定義方法
var a = [...]int{1,2,3} //數組的長度由元素的個數決定
//初始化方法
var a = [5] int{1,2,3,4,5}
var a = [5] int{1,2,3}
var a = [...]int{1,2,3,4}
var a = [5]string{1:"go",3:"python"}
ps : 數組的長度也是數組類型的一部分,所以[3]int 與 [4]int其實是不同的類型
默認情況下一個新的數組的元素初始值爲元素類型的零值
指針數組
var num_ptrs [10] * int
函數傳遞參數
func name(a [] int ) {
}
func name(a [10] int) {
}
其他關於數組的知識後面再補充,下面講一下切片
切片
slice 表示一個擁有相同類型元素的可變長的序列。
數組的長度不可改變,在特定場景中這樣的集合就不太適用,Go中提供了一種靈活,
功能強悍的內置類型Slices切片(“動態數組"),與數組相比切片的長度是不固定的,可以追加元素,在追加時可能使切片的容量增大。
切片中有兩個概念:
- 一是len長度,二是cap容量,長度是指已經被賦過值的最大下標+1,可通過內置函數len()獲得。
- 容量是指切片目前可容納的最多元素個數,可通過內置函數cap()獲得。
切片是引用類型,因此在當傳遞切片時將引用同一指針,修改值將會影響其他的對象
- s :=[] int {1,2,3 }
直接初始化切片,[]表示是切片類型,{1,2,3}初始化值依次是1,2,3.其cap=len=3 - s := arr[:]
初始化切片s,是數組arr的引用 - s := arr[startIndex:endIndex]
將arr中從下標startIndex到endIndex-1 下的元素創建爲一個新的切片 - s := arr[startIndex:]
缺省endIndex時將表示一直到arr的最後一個元素 - s := arr[:endIndex]
缺省startIndex時將表示從arr的第一個元素開始 - s1 := s[startIndex:endIndex]
通過切片s初始化切片s1 - s :=make([]int,len,cap)
通過內置函數make()初始化切片s,[]int 標識爲其元素類型爲int的切片
賦值和使用
切片是引用類型,在使用時需要注意其操作。切片可以通過內置函數append(slice []Type,elems ...Type)追加元素,elems可以是一排type類型的數據,也可以是slice,因爲追加的一個一個的元素,因此如果將一個slice追加到另一個slice中需要帶上"...",這樣才能表示是將slice中的元素依次追加到另一個slice中。另外在通過下標訪問元素時下標不能超過len大小,如同數組的下標不能超出len範圍一樣。
- s :=append(s,1,2,3,4)
- s :=append(s,s1...)
slice創建
內置函數make可以創建一個具有指定元素類型、長度和容量的slice,其中容量參數可以省略,這樣默認slice的長度和容量就相等了
make([]type,len,cap)
make([]type,len)
現在說說關於:
make([]type,len)
make([]type,len,cap)
其實make創建了一個無名數組並返回了它的一個slice;這個數組僅可以通過slice來訪問。
第一個:make([]type,len)返回的slice引用了整個數組。
第二個:make([]type,len,cap)slice只引用了數組的前len個元素,但是它的容量是數組的長度
通過下圖理解切片的創建過程:
關於copy
該函數主要是切片(slice)的拷貝,不支持數組
將第二個slice裏的元素拷貝到第一個slice裏。如果加入的兩個數組切片不一樣大,就會按其中較小的那個數組切片的元素個數進行復制。