Golang-Map

简介: Golang-Map

Go语言中提供的映射关系容器为map,其内部使用散列表(hash)实现map

map是一种无序的基于key-value的数据结构,Go语言中的map是引用类型,必须初始化才能使用。


定义Map


// 初始化定义map[KeyType]ValueType// KeyType:表示键的类型。map可以嵌套map,可以是key 也是是value// ValueType:表示键对应的值的类型。map类型的变量默认初始值为nil,需要使用make()函数来分配内存。语法为:make(map[KeyType]ValueType, [cap])// 赋值定义map[KeyType]ValueType{
  key1:value1
  key2:value2
  key4:value3
}


示例


package mainimport "fmt"func main() {
    a := make(map[string]string)
    a["name"] = "Payne"
    a["sex"] = "male"
    a["year"] = "20"
    fmt.Println("a:", a)               // a: map[name:Payne sex:male year:20]
    fmt.Println("a['sex']:", a["sex"]) // a['sex']: male
    fmt.Printf("Type of a:%T\n", a)      // Type of a:map[string]string
    b := map[string]string{        "Name": "Tim",        "Sex":  "male",        "Year": "20",
    }
    fmt.Println("b:", b)               // b: map[Name:Tim Sex:male Year:20]
    fmt.Println("b['sex']:", b["Sex"]) // b['sex']: male
    fmt.Printf("Type of b:%T", b)   // Type of b:map[string]string}


判断某个键是否存在


Go语言中有个判断map中键是否存在的特殊写法,格式如下:


value, ok := map[key]// 其中 value可以为任意接受值。而 ok 必须写


示例


package mainimport "fmt"func main() {
    c := map[string]string{        "name1": "Tom",        "name2": "Tim",        "name3": "Payne",        "name4": "John",
    }    // 如果key存在ok为true,v为对应的值;// 不存在ok为false,v为值类型的零值
    value, ok := c["name1"]
    fmt.Println(value, ok)     // Tom true
    value, ok := c["name5"]
    fmt.Println(value, ok)     // false
  if ok {
    fmt.Println(value)             // Tom
  } else {
        fmt.Println("nil")
    }
}


map遍历


Go语言中使用for range遍历map。


示例


// 遍历
    d := map[string]string{        "name1": "Tom",        "name2": "Tim",        "name3": "Payne",        "name4": "John",
    }    // 只遍历key
    for d := range d {
        fmt.Print(d + ",")  // name1,name2,name3,name4,
    }
    fmt.Printf("\n")    // 只遍历value
    for _, v := range d {
        fmt.Print(v + ",")  // Tom,Tim,Payne,John,
    }
    fmt.Printf("\n")    // 遍历key value
    for k, v := range d {
        fmt.Print(k, ":", v, " ")   // name2:Tim name3:Payne name4:John name1:Tom
    }


删除key


使用delete()内建函数从map中删除一组键值对,delete()函数的格式如下:


delete(map, key)// map:表示要删除键值对的map// key:表示要删除的键值对


示例


f := map[string]string{        "name1": "Tom",        "name2": "Tim",        "name3": "Payne",        "name4": "John",
    }
    v1, ok := f["name1"]
    fmt.Println(v1, ok)  // Tom true
    delete(f, "name1")
    v2, ok := f["name1"]
    fmt.Println(v2, ok)  // false


元素为map类型的切片


下面的代码演示了切片中的元素为map类型时的操作:


func main() {
  mapSlice := make([]map[string]string, 3)    for index, value := range mapSlice {
        fmt.Printf("index:%d value:%v\n", index, value)
    }
    fmt.Println("after init")    // 对切片中的map元素进行初始化
    mapSlice[0] = make(map[string]string, 10)
    mapSlice[0]["name"] = "payne"
    mapSlice[0]["password"] = "123456"
    mapSlice[0]["address"] = "cs"
    for index, value := range mapSlice {
        fmt.Printf("index:%d value:%v\n", index, value)
    }
}// index:0 value:map[]// index:1 value:map[]// index:2 value:map[]// after init// index:0 value:map[address:cs name:payne password:123456]// index:1 value:map[]// index:2 value:map[]


值为切片类型的map


下面的代码演示了map中值为切片类型的操作:


func main() {
  sliceMap := make(map[string][]string, 3)
    fmt.Println(sliceMap)
    fmt.Println("after init")
    key := "中国"
    value, ok := sliceMap[key]    if !ok {
        value = make([]string, 0, 2)
    }
    value = append(value, "北京", "上海")
    sliceMap[key] = value
    fmt.Println(sliceMap)
}// map[]// after init// map[中国:[北京 上海]]


总结


可以map理解为key-value的容器,里面可包含基本数据类型\Map,不包含Array。包含sclice

Payne
+关注
目录
打赏
0
0
0
0
2
分享
相关文章
|
8月前
|
通义灵码测评
作为一名运维人员,通过使用通义灵码进行业务、功能及环境测试,显著提高了工作效率。以前需自行查找或编写代码,不仅速度慢且易出错。通义灵码能够快速响应需求,即时生成所需代码,大幅减少错误和修改时间,优化了工作流程。
116 1
CNCF 宣布 Dapr 毕业
Dapr 是一个可移植的分布式应用运行时,提供集成 API,帮助开发者构建可靠和安全的分布式应用,提升生产力 20-40%。Dapr 于 2019 年由微软发布,并于 2021 年 11 月正式加入 CNCF。截至 2024 年 11 月 13 日,Dapr 已正式从 CNCF 毕业。它支持多种云原生技术,广泛应用于 Grafana、FICO、HDFC 银行等企业。
181 2
看看AI大佬都开了什么公司 | AI大咖说
看看AI大佬都开了什么公司 【10月更文挑战第6天】
571 1
Kubernetes 中的对象是如何删除的:Finalizers 字段介绍
Kubernetes 中的对象删除并不像表面上看起来那么简单,删除对象涉及一系列过程,例如对象的级联和非级联删除,在删除之前检查以确定是否可以安全删除对象等等。这些都是通过称为 `Finalizers`(终结器)的 API 对象实现的。
1262 0
Kubernetes 中的对象是如何删除的:Finalizers 字段介绍
「开源人说」第五期 | KubeVela:一场向应用交付标准的“冲锋”
「开源人说」第五期聚焦云原生领域开源至今仅两年多的项目——KubeVela,将镜头对准 KubeVela 项目背后的代码贡献者和落地实践者,讲述这个从第一天就诞生在社区的技术,如何走到对不同场景应用“海纳百川”,直至成为 CNCF 孵化项目,并逐渐向应用交付领域的事实标准演进的故事。 阅读下文,让我们跟随 KubeVela 创始团队,一起了解它的开源背后的故事。
199846 1
「开源人说」第五期 | KubeVela:一场向应用交付标准的“冲锋”
SREWorks云原生数智运维工程实践-SREWorks 介绍篇-一看就会的SREWorks快速入门-安装平台底座
SREWorks云原生数智运维工程实践-SREWorks 介绍篇-一看就会的SREWorks快速入门
487 0
阮一峰:炫耀从来不是我的动机,好奇才是(图灵访谈)
阮一峰:炫耀从来不是我的动机,好奇才是(图灵访谈)
1184 0
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等

登录插画

登录以查看您的控制台资源

管理云资源
状态一览
快捷访问