搜索
您的当前位置:首页正文

区块链 GO Map

来源:二三娱乐

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!
Top