區(qū)塊鏈 GO Map

Map 是一種無序的鍵值對的集合。Map 最重要的一點是通過 key 來快速檢索數(shù)據(jù),key 類似于索引,指向數(shù)據(jù)的值。

Map 是一種集合,所以我們可以像迭代數(shù)組和切片那樣迭代它。不過,Map 是無序的,我們無法決定它的返回順序,這是因為 Map 是使用 hash 表來實現(xiàn)的。

Map的聲明

聲明的map是nil

var map_name map[string]string

var dic map[string]string 

//默認(rèn)map是nil ,它與一個空map基本等價,只是nil的map不允許往里面添加值。(A nil map is equivalent to an empty map except that no elements may be added)
因此,map是nil時,取值是不會報錯的(取不到而已),但增加值會報錯。
通過fmt打印map時,空map和nil map結(jié)果是一樣的,都為map[]。所以,這個時候別斷定map是空還是nil,而應(yīng)該通過map == nil來判斷。

聲明的map是null

var map_name = map[type]type{}
var dic = map[string]string{} // NULL
var dic1 = map[int]string{}//or:  dic1 := map[int]string{}


package main

import "fmt"

func main() {
    // 初始化一個map,map我們也經(jīng)常叫做字典
    var dic = map[string]string{} // NULL
    // ""
    fmt.Println(dic)
    fmt.Printf("%T\n", dic)
    fmt.Println(len(dic))
    dic["name"] = "zhang"
    fmt.Println(dic)
    fmt.Println(len(dic))
    fmt.Println(dic == nil)
}
輸出為:
map[]
map[string]string
0
map[name:zhang]
1
false

如果這么聲明 dic1 := map[int]string{}
請注意“}”與“,”的寫法
dic := map[string]string{
        "name": "zelin",
        "age": "18", //如果 “}”和30這個字符串挨在一起,最后這個”,“可以不需要,否則必須添加
    } 
map 最好使用 make 函數(shù)初始化

通過向 make 函數(shù)傳入鍵和值的類型,可以創(chuàng)建 map。
make(map[type of key]type of value) 是創(chuàng)建 map 的語法。

myGreeting := make(map[string]string) //NULL
等價于下面三種寫法
// var myGreeting = make(map[string]string)
// myGreeting := map[string]string{}
// var myGreeting = map[string]string{}

myGreeting["Tim"] = "Good morning"
myGreeting["Jenny"] = "Bonjour"

fmt.Println(myGreeting)
// 返回字典鍵值對的個數(shù)
fmt.Println(len(myGreeting))
輸出為:
map[Tim:Good morning Jenny:Bonjour]
2
map的使用
map的增,刪,改,查
package main

import "fmt"

func main() {
    dic := map[int]string{
        1: "張三",
        2: "李四",
        3: "王五",
        4: "找六",
    }

    fmt.Println(dic)

    // 更新num one
    dic[1] = "ze lin"

    fmt.Println(dic)

    // 添加
    dic[5] = "澤林"
    fmt.Println(dic)

    // 刪除
    // func delete(m map[Type]Type1, key Type)
    // 如果函數(shù)有返回值,會將原來的數(shù)據(jù)重新拷貝一份新的空間,如果沒有返回值,那么是在原來的空間里面直接修改數(shù)據(jù)
    // delete(map[typeA]typeB, typeA)
    delete(dic, 3)
    fmt.Println(dic)

    // 查詢
    fmt.Println(dic[1])

}
輸出為:
map[1:張三 2:李四 3:王五 4:找六]
map[1:ze lin 2:李四 3:王五 4:找六]
map[3:王五 4:找六 5:澤林 1:ze lin 2:李四]
map[5:澤林 1:ze lin 2:李四 4:找六]
ze lin
判斷key是否存在的問題
package main

import "fmt"

func main() {
    dic := map[string]string{
        "name": "zelin",
        "tel":  "185........",
    }
    // age

    if name, isExist := dic["name"]; isExist {
        fmt.Println(name)
        fmt.Println(isExist)
    }

    if val, ok := dic["age"]; !ok {
        fmt.Println(val)
        fmt.Println(ok)
    }

}
輸出為:
zelin
true

false
遍歷 map
遍歷 map 中所有的元素需要用 for range 循環(huán)。
package main

import "fmt"

func main() {

    myGreeting := map[int]string{
        0: "Good morning!",
        1: "Bonjour!",
        2: "Buenos dias!",
        3: "Bongiorno!",
    }

    // for index := 0; index < len(myGreeting); index++ {

    // }

    for key, val := range myGreeting {
        fmt.Println(key, " - ", val)
    }
}
輸出為:
0  -  Good morning!
1  -  Bonjour!
2  -  Buenos dias!
3  -  Bongiorno!
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容