這節課我們來講解數組,切片和map,或許您是從其餘語言轉到GO語言這邊的,那麼在其餘語言的影響下您可能會不太適應GO語言的數組,因為GO語言把數組給拆分紅了array,slice和map,接下來的時間讓我們一塊兒研究一下這三者的差異以及用法.首先我們說一下array的部份:
1.數組的長度屬於數組的一部份,我們看下邊的例子
a:=[1]int{}和b:=[2]int{}
a和b都是數組,可是他們的長度不一樣,在GO語言中會認為是不一樣的兩種類型,既然是不一樣的類型,那麼他們就不能進行比較或直接賦值的操做.其實這並不難理解,因為GO語言是類型安全的語言,跨越類型的賦值須要顯示的改變數據類型才行.
2.在GO語言中數組屬於值類型,而非引用類型,若是要取得數組的指針只須要這麼作便可.
a:=[1]int{};p:=&a
通過上邊的語句就能夠取得數組的指針,並把指針賦值給了變量p
3.array的鍵名只能用整型或字符型,並且下標從零開始
array的定義格式為:
var 數組變量名 = [長度]類型{}
接下來讓我們來看這段代碼:
a1:=[2]int{} //聲明一個數組,不賦予初始值,因此數組中每一個元素的值都是int的初值
a2:=[2]int{1,2} //聲明一個數組,並賦予初始值
a3:=[2]int{1:2} //聲明一個數組,給[1]賦初始值
fmt.Println(a1);
fmt.Println(a2);
fmt.Println(a3);
p1:=&a1 //取得a1這個數組的指針
fmt.Println(p1);
b:=[3]string{"aa","bb","cc"} //聲明一個string類型的數組,並賦予初始值
c:=[...]string{"aa","bb","cc"} //聲明一個數組,不設定長度,用三個點告訴GO語言本身計算數組長度
fmt.Println(b);
fmt.Println(c);
fmt.Println(b==c); //比較兩個數組是否相同
c[1]="BB" //修改[1]的值
fmt.Println(b==c); //比較兩個數組是否相同
fmt.Println(cap(c)); //取得數組容量
fmt.Println(len(c)); //取得數組長度
//array的鍵名必須是數字或字節
d:=[...]int{96:3,'a':4} //用字符做為鍵名,因為每個字符實際上是對應了一個int型的序號,因此其實鍵名還是int型的
fmt.Println(d);
e:=[2][3]int{{1,1,1},{2,2,2}} //聲明一個二維數組
fmt.Println(e);
f:=[...][3]int{{1,1,1},{2,2,2}} //聲明一個多維數組,維數讓GO語言來計算
fmt.Println(f);
p:=new([4]int) //這是另一種聲明數組的方法,能夠用new關鍵字,可是這種聲明方法會返回指向數組的指針
fmt.Println(p);
接下來讓我們來一塊兒看一下slice切片,切片的部份須要你們知道如下幾個要點:
1.切片自己不是一個數組,可是他的底層指向其餘的數組
2.用切片能夠達到變長數組的特性,我們知道array的長度是固定的
3.切片是引用類型,我們知道array是值類型
4.切片用make關鍵字創建,array用new
5.若多個切片指向同一個數組,當這個數組的某個值被改變後,全部的切片的值也跟這邊,這就是引用類型的特性.
創建切片的語法格式以下:
切片名 = make([]數組名,長度,容量)
讓我們來看一下切片的用法吧:
//s=make([]int,3,5) //這是標準的定義方式,定義切片的時候同時分配內存
//fmt.Println(s);
a:=[...]int{1,2,3,4,5,6,7,8,9,0}
fmt.Println(a);
s:=[]int{} //定義一個切片
fmt.Println(s);
s=a[5:] //讓該切片指向數組a,同時為其賦值
fmt.Println(s);
x:=a[4:9]
fmt.Println("x的值是:",x);
a[7]=99 //改變數組的某個值
fmt.Println(s); //打印切片,發現值也變了
fmt.Println("x的值是:",x); //此時切片的值也被改變了
s=a[:] //取得全部的元素
fmt.Println(s);
最後我們看一下map的用法,map與數組或切片不一樣,我們來看一下有哪些不一樣點
1.map使用key-value的方式來存儲,key值再也不侷限於int型,能夠是字符串之類的值
2.map比數組或切片慢不少,因此若是能用數組或切片的情況下儘量別用map
3.map跟切片一樣是使用make來創建,這一點和數組的new是不一樣的
4.map用delete刪除某個元素
5.用range對map或切片進行迭代操做.
接下來我們看一下map的基本用法:
var m1 = map[string]float64{"Bell Labs": 40.68433,"Google":37.42202}
m1["new"]=1.01 //新增鍵值對
fmt.Println("三個元素:",m1)
delete(m1,"new")
fmt.Println("兩個元素:",m1)
fmt.Println(m1); //此時鍵["new"]已經不存在了
for k, v := range m1 { //迭代遍歷map
fmt.Printf("m1[%s]=%f\n", k, v)
}
fmt.Printf("m1的長度是 %d \n", len(m1))
m := make(map[string]int) //用make創建map
m["k1"] = 7
m["k2"] = 13
fmt.Println("map:", m)
由此可見array;slice;map每個都有各自不一樣的用法,另外在效能上也有差異,在平常使用時建議使用array和slice,map雖然更靈活只惋惜效能不夠高.
但願轉載文章的朋友能夠留一個文章出處,http://blog.csdn.net/sibang 在此感激不盡!
剛成立了一個QQ羣,有興趣討論GO語言的朋友能夠加入:195112安全