美文网首页Go
区块链 GO Map

区块链 GO Map

作者: ze__lin | 来源:发表于2018-01-21 18:04 被阅读52次

    Map 是一种无序的键值对的集合。Map 最重要的一点是通过 key 来快速检索数据,key 类似于索引,指向数据的值。

    Map 是一种集合,所以我们可以像迭代数组和切片那样迭代它。不过,Map 是无序的,我们无法决定它的返回顺序,这是因为 Map 是使用 hash 表来实现的。

    Map的声明

    声明的map是nil

    var map_name map[string]string
    
    var dic map[string]string 
    
    //默认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结果是一样的,都为map[]。所以,这个时候别断定map是空还是nil,而应该通过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我们也经常叫做字典
        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 函数初始化

    通过向 make 函数传入键和值的类型,可以创建 map。
    make(map[type of key]type of value) 是创建 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)
    // 返回字典键值对的个数
    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)
        // 如果函数有返回值,会将原来的数据重新拷贝一份新的空间,如果没有返回值,那么是在原来的空间里面直接修改数据
        // 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 循环。
    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!
    

    相关文章

      网友评论

        本文标题:区块链 GO Map

        本文链接:https://www.haomeiwen.com/subject/ibrqaxtx.html