GO語言基礎教程:數組,切片,map


    這節課我們來講解數組,切片和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安全

相關文章
相關標籤/搜索