Go 语言入门很简单 -- 8. Go Maps #私藏项目实操分享#

简介: Go 语言入门很简单 -- 8. Go Maps #私藏项目实操分享#

映射

映射也是 Go 内置的数据结构,用于存储键值对的无序集合。

也被称为关联数组、哈希表字典。类似与查字典,映射用于通过关键键查找关联的值。键是唯一的,键对应的值可以通过键来获取、更新或删除。 可以利用映射来检测一个键是否已经存在。值存储后,可以通过引用相关的键来调用映射的值。

image.png

映射的定义

以下是 Go 中映射的定义:

var x map[string] int

映射类型由关键字 map 表示,后跟括号中的类型,最后是类型。

image.png

映射的散列表包含一组桶。在存储、删除或查找键值对的时候,所有的操作要先选择一个桶。把操作映射时指定的键传给映射的散列函数,就能选中对应的桶。这个散列函数的目的是生成一个索引,这个索引最终将键值对分布到所有可用的桶里。

如上图所示,桶的内部实现。映射使用两个数据结构来存储数据:

  • 第一个数据结构是一个数组,内部存储的是用于选择桶的散列值的高八位值。这个数组用于区分每个键值对要存在哪个桶里。
  • 第二个数据结构是一个字节数组,用于存储键值对。改字节数组依次存储了这个桶里所有的键,之后一次存储了这个桶里所有的值。

这种键值对的存储方法的目的:减少每个桶里所需的内存

image.png

类似于数组和切片,同样可以使用中括号 [] 来访问映射,

package main
import "fmt"
func main() {
    my_map := make(map[string]int)  // 创建一个从string到int的
    my_map["小李"] = 18
    my_map["老张"] = 50
    fmt.Println(my_map)
    fmt.Printf("老张今年%d岁.", my_map["老张"])
}

运行该代码,结果为:

map[小李:18 老张:50]
老张今年50岁.

也可以使用 map 字面量来创建一个带初始化键值对元素的映射:

ages := map[string]int{
    "小李": 18,
    "老张": 30,
    "老罗": 45,
}

可以使用内置函数 delete 来从字典中根据键移除一个元素:

delete(ages, "老张") // 删除 ages["老张"]

映射遍历

可以使用 for...range 循环来遍历 map 中所有的键和对应的值,就像遍历 slice 一样。在每次迭代中获得键值对,但是每一次遍历可能会不一样,即迭代顺序是随机的。

package main
import "fmt"
func main() {
    ages := map[string]int{
        "小李": 18,
        "老张": 30,
        "老罗": 45,
    }
    for name, age := range ages {
        fmt.Println(name, age)
    }
}

运行结果为:

小李 18
老张 30
老罗 45

映射排序

映射中元素的迭代顺序是不固定的,不同的实现方法会使用不同的散列算法,得到不同的元素顺序。如果需要按照某种顺序来遍历映射中的元素,可以显式的给键排序。

像上述的例子中,键是字符串类型,可以使用 sort 包中的 Strings 函数来进行键的排序:

package main
import (
    "fmt"
    "sort"
)
func main() {
    var names []string
    ages := map[string]int{
        "小李": 18,
        "老张": 30,
        "老罗": 45,
    }
    for name, age := range ages {
        fmt.Println(name, age)
    }
    fmt.Println("--- 排序后 ---")
    for name := range ages {
        names = append(names, name)
    }
    sort.Strings(names)
    for _, name := range names {
        fmt.Printf("%s\t%d\n", name, ages[name])
    }
}

运行后,得到结果:

老罗 45
小李 18
老张 30
--- 排序后 ---
小李  18
老张  30
老罗  45

映射是引用类型

映射也是引用类型。 将映射分配给新变量时,它们都引用相同的底层数据结构。 因此,一个变量更改,对另一个变量也会被相应的更改。 例子如下:

package main
import (
    "fmt"
)
func main() {
    var my_map = map[int]string{
        64: "new Zealand",
        3:  "Russia",
        44: "UK",
        61: "Australia",
        81: "Japan",
        91: "India",
    }
    fmt.Println("初始 map: ", my_map)
    // 赋值给新 map
    new_map := my_map
    // 新 map 中进行添加
    new_map[86] = "China"
    new_map[33] = "France"
    fmt.Println("new_map: ", new_map)
    fmt.Println("修改后的初始 map: \n", my_map)
}

运行结果:

初始 map:  map[3:Russia 44:UK 61:Australia 64:new Zealand 81:Japan 91:India]
new_map:  map[3:Russia 33:France 44:UK 61:Australia 64:new Zealand 81:Japan 86:China 91:India]
修改后的初始 map: 
 map[3:Russia 33:France 44:UK 61:Australia 64:new Zealand 81:Japan 86:China 91:India]

总结

Map 是 Golang 中键值对的无序集合。键在映射中是唯一的,但值可能不是。它被广泛使用,因为它提供了可以在键的帮助下检索、更新或删除的快速查找和值。

在 Golang 中,映射也称为关联数组、哈希表或字典。 映射用于通过其关联的键查找值。

一个映射的零值是 nil 并且一个 nil 映射没有键。 因此,任何将键添加到 nil 映射的尝试都将导致运行时错误。

在 Go 中,您可以使用内置的 make() 函数初始化映射。 它就会返回一个已初始化并可随时使用的映射。

可以使用 Go 编程语言中 for...range 循环的范围形式迭代映射。

在 Golang 中,映射是一个无序集合,因此,不能保证每次迭代时映射的迭代顺序都相同。因此,如果您多次运行任何程序,您将获得不同顺序的结果。

Maps 是 Golang 中的引用类型。 将映射分配给新变量时,它们都引用相同的底层数据结构。 因此,一个变量所做的更改,另一个变量相应会被更改。


相关文章
|
2月前
|
Cloud Native 安全 Java
Go语言深度解析:从入门到精通的完整指南
🌟蒋星熠Jaxonic,Go语言探索者。深耕云计算、微服务与并发编程,以代码为笔,在二进制星河中书写极客诗篇。分享Go核心原理、性能优化与实战架构,助力开发者掌握云原生时代利器。#Go语言 #并发编程 #性能优化
404 43
Go语言深度解析:从入门到精通的完整指南
|
2月前
|
存储 安全 Java
【Golang】(4)Go里面的指针如何?函数与方法怎么不一样?带你了解Go不同于其他高级语言的语法
结构体可以存储一组不同类型的数据,是一种符合类型。Go抛弃了类与继承,同时也抛弃了构造方法,刻意弱化了面向对象的功能,Go并非是一个传统OOP的语言,但是Go依旧有着OOP的影子,通过结构体和方法也可以模拟出一个类。
179 1
|
3月前
|
Cloud Native 安全 Java
Go语言深度解析:从入门到精通的完整指南
🌟 蒋星熠Jaxonic,执着的星际旅人,用Go语言编写代码诗篇。🚀 Go语言以简洁、高效、并发为核心,助力云计算与微服务革新。📚 本文详解Go语法、并发模型、性能优化与实战案例,助你掌握现代编程精髓。🌌 从goroutine到channel,从内存优化到高并发架构,全面解析Go的强大力量。🔧 实战构建高性能Web服务,展现Go在云原生时代的无限可能。✨ 附技术对比、最佳实践与生态全景,带你踏上Go语言的星辰征途。#Go语言 #并发编程 #云原生 #性能优化
|
4月前
|
Cloud Native Go API
Go:为云原生而生的高效语言
Go:为云原生而生的高效语言
382 0
|
4月前
|
Cloud Native Java Go
Go:为云原生而生的高效语言
Go:为云原生而生的高效语言
245 0
|
4月前
|
Cloud Native Java 中间件
Go:为云原生而生的高效语言
Go:为云原生而生的高效语言
222 0
|
10月前
|
编译器 Go
揭秘 Go 语言中空结构体的强大用法
Go 语言中的空结构体 `struct{}` 不包含任何字段,不占用内存空间。它在实际编程中有多种典型用法:1) 结合 map 实现集合(set)类型;2) 与 channel 搭配用于信号通知;3) 申请超大容量的 Slice 和 Array 以节省内存;4) 作为接口实现时明确表示不关注值。此外,需要注意的是,空结构体作为字段时可能会因内存对齐原因占用额外空间。建议将空结构体放在外层结构体的第一个字段以优化内存使用。
|
4月前
|
Cloud Native 安全 Java
Go:为云原生而生的高效语言
Go:为云原生而生的高效语言
291 1
|
10月前
|
运维 监控 算法
监控局域网其他电脑:Go 语言迪杰斯特拉算法的高效应用
在信息化时代,监控局域网成为网络管理与安全防护的关键需求。本文探讨了迪杰斯特拉(Dijkstra)算法在监控局域网中的应用,通过计算最短路径优化数据传输和故障检测。文中提供了使用Go语言实现的代码例程,展示了如何高效地进行网络监控,确保局域网的稳定运行和数据安全。迪杰斯特拉算法能减少传输延迟和带宽消耗,及时发现并处理网络故障,适用于复杂网络环境下的管理和维护。
|
4月前
|
Cloud Native Java Go
Go:为云原生而生的高效语言
Go:为云原生而生的高效语言
318 0