• map以散列表方式存储键值对集合

  • map中每个元素都是键值对

map[key]Value
  • key是操作map的唯一标准.可以通过key对map中元素进行增加/删除/修改/查看

  • key是唯一的,添加重复的key会覆盖之前的元素.

  • map是值类型,只声明时为空指针(nil)

    var m map[string]int
    fmt.Println(m == nil) //输出:true
    fmt.Printf("%p", m)   //输出:0x0
  • map读写数据时并不是并发安全的,可以结合RWMutex保证并发安全(RWMutex在后面讲解)

实例化map的几种方式

  • 使用make函数实例化一个没有初始值的map

    m := make(map[string]string)
    fmt.Println(m==nil)//输出:false
    fmt.Printf("%p", m)//输出:内存地址
  • 可以在声明map时直接给map赋初始值.注意初始值在一行和在多行写时的语法区别

    • map中元素键值对语法满足: key:value

    • key和value的类型必须和map[key]value类型严格对应

    m := map[string]string{"name": "smallming", "address": "北京海淀"}
    m1 := map[string]string{
        "name":     "smallming",
        "addresss": "北京海淀",
    }
    fmt.Println(m, m1)

操作map中的元素

  • 使用key判断,如果key不存在向map中新增数据,如果key存在会覆盖map中元素

    m := make(map[string]int)
    m["money"] = 5
    fmt.Println(m) //输出:map[money:5]
    m["money"] = 6
    fmt.Println(m) //map[money:6]
  • Go语言标准库中提供了对map元素删除的函数,使用顶层delete()即可完成删除

    • 如果key存在执行删除元素

    • 如果key不存在,map中内容不变,也不会有错误

    m := make(map[string]int)
    m["money"] = 5
    delete(m, "没有的key")
    fmt.Println(m) //输出:map[money:5]
    delete(m, "money")
    fmt.Println(m) //输出:map[]
  • 获取map中指定key对应的值

    • 使用:map变量[key]获取key对应的值

    • 如果key不存在返回map[key]Value中Value类型的默认值.例如:Value是string类型就返回""

    • 返回值可以是一个,也可以是两个.

      • 一个表示key对应的值

      • 两个分别表示:key对应的值和这个key是否存在

    m := map[string]string{"name": "smallming", "address": "北京海淀"}
    fmt.Println(m["name"]) //输出:smallming
    fmt.Println(m["age"])  //输出:空字符串
    value, ok := m["age"]
    fmt.Println(value, ok) //输出:空字符串 false
  • 如果希望把map中所有元素都遍历,可以使用for结合range实现
    m := map[string]string{"name": "smallming", "address": "北京海淀"}
    //range遍历map时返回值分别表示key和value
    for key, value := range m {
        fmt.Println(key, value)
    }
12-30 02:02