为了账号安全,请及时绑定邮箱和手机立即绑定

Go 快速入门指南 - Map

标签:
Go

概述

Map 是一种键值对的无序集合,在其他编程语言中也被称为 字典, Hash, 关联数组

重要的一点是: Map 键 的数据类型必须是可以比较的,例如 string, int, float64, 具体的类型比较规则后面的章节会讲到,读者可以先使用简单数据类型来进行实验。

Map 值 的数据类型可以是任意的。

语法规则

# 声明
var 变量名 map[键数据类型]值数据类型

# 声明及初始化
var 变量名 = make(map[键数据类型]值数据类型, 长度)   // 长度参数可以省略

获取值/改变值

package main

import "fmt"

func main() {
    var m = make(map[string]int)

    fmt.Printf("Map 长度 = %d\n", len(m))

    m["zero"] = 0
    m["one"] = 1
    m["two"] = 2

    fmt.Printf("Map 长度 = %d\n", len(m))

    fmt.Printf("zero = %T, %v\n", m["zero"], m["zero"])
    fmt.Printf("one = %T, %v\n", m["one"], m["one"])
    fmt.Printf("two = %T, %v\n", m["two"], m["two"])
}

// $ go run main.go
// 输出如下 
/**
  Map 长度 = 0
  Map 长度 = 3
  zero = int, 0
  one = int, 1
  two = int, 2
*/

删除元素

调用 delete() 方法完成。

package main

import "fmt"

func main() {
    var m = make(map[string]int)

    fmt.Printf("Map 长度 = %d\n", len(m))

    m["zero"] = 0
    m["one"] = 1
    m["two"] = 2

    fmt.Printf("Map 长度 = %d\n", len(m))

    delete(m, "one")
    delete(m, "two")

    fmt.Printf("Map 长度 = %d\n", len(m))
}

// $ go run main.go
// 输出如下 
/**
  Map 长度 = 0
  Map 长度 = 3
  Map 长度 = 1
*/

判断元素是否存在

package main

func main() {
    var m = make(map[string]int)

    m["zero"] = 0
    m["one"] = 1
    m["two"] = 2

    if _, ok := m["zero"]; ok {
        println(`m["zero"] 元素存在`)
    }

    delete(m, "zero")

    if _, ok := m["zero"]; !ok {
        println(`m["zero"] 元素不存在`)
    }
}

// $ go run main.go
// 输出如下 
/**
  m["zero"] 元素存在
  m["zero"] 元素不存在
*/

遍历 Map

重要的一点是: Map 遍历是无序的。 所以不能依赖于遍历的顺序,不论是 还是 , 如果需要遍历时永远保持相同的顺序,需要提前将 做排序处理,参考 有序 Map 小节。

package main

import "fmt"

func main() {
    var m = make(map[string]int)

    m["zero"] = 0
    m["one"] = 1
    m["two"] = 2

    for k, v := range m {
        fmt.Printf("key = %s, val = %d\n", k, v)
    }

    println("\n遍历 3 次,每次输出的结果可能不一样\n")
    for i := 0; i < 3; i++ {
        for k, v := range m {
            fmt.Printf("key = %s, val = %d\n", k, v)
        }
        fmt.Printf("第 %d 次遍历完成\n\n", i+1)
    }
}

// $ go run main.go
// 输出如下 
/**
  key = zero, val = 0
  key = one, val = 1
  key = two, val = 2

  遍历 3 次,每次输出的结果可能不一样

  key = one, val = 1
  key = two, val = 2
  key = zero, val = 0
  第 1 次遍历完成

  key = zero, val = 0
  key = one, val = 1
  key = two, val = 2
  第 2 次遍历完成

  key = one, val = 1
  key = two, val = 2
  key = zero, val = 0
  第 3 次遍历完成
*/

备注: 你的输出应该和这里不一样,多运行几次,看看是否每次都不一样。

并发不安全

最后要说明的很重要的一点是: Map 不是并发安全的, 也就是说,如果在多个线程中,同时对一个 Map 进行读写,会报错。 互斥锁 提供了一个简单的解决方案,后面会专门写一篇文档来说明如何才能 并发安全

点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
全栈工程师
手记
粉丝
0
获赞与收藏
0

关注作者,订阅最新文章

阅读免费教程

  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消