首先Map是Golang中的内置类型,它以键值对的形式存在,即将一个值与一个键关联起来,也就是说可以使用相应的键来检索对应的值。
Map是一种无序的键值对的集合,我们可以像迭代数组和切片那样迭代它,由于Map是无序的,因此无法决定它的返回顺序,这跟实现 Map 的数据结构有关,是使用 hash 表来实现的,也是引用类型。
使用Map 过程中注意事项:
Map 是无序的,每次打印出来的结果都会不一样,它不能通过索引来获取,而必须通过key获取
Map 的长度是动态的,也就是和slice类型,也是一种引用类型
内置的len函数同样适用于map,返回map拥有的key的数量
Map 的key可以是所有可比较的类型,如布尔型、整数型、浮点型、复杂型、字符串型等
创建map类型的变量可以使用 map 关键字来定义 Map,也可以使用内建函数 make 来创建,语法如下:
// 声明变量map_variable,默认为nilvar mapData map[string]string// 使用 make 函数定义变量mapData = make(map[string]string)
创建Map时,如果不初始化,则会创建一个 nil 的map,此时的 map 不能用来存放键值对。Map使用举例代码如下:
package mainimport "fmt"func main() {
var cityMap map[string]string // 创建cityMap变量 cityMap = make(map[string]string) // map 插入 key-value 键值对 cityMap["France"] = "Paris" cityMap["Italy"] = "Rome" cityMap["Japan"] = "Tokyo" cityMap["India"] = "New Delhi" /* 使用 key 输出 map 值 */ for city := range cityMap {
fmt.Println("Capital of", city,"is", cityMap[city]) } // 用带ok的返回值来查看元素在集合中是否存在 cityCap, ok := cityMap["United States"] // 如果 ok 是 true, 则存在,否则不存在 if ok {
fmt.Println("Capital of United States is", cityC) }else {
fmt.Println("Capital of United States is not present") }}
输出结果:
Capital of France is ParisCapital of Italy is RomeCapital of Japan is TokyoCapital of India is New DelhiCapital of United States is not present
使用len函数可以确定map的长度。比如:
len(map) // 可以得到map的长度
Golang内置的 delete(map, key) 函数用于删除集合的元素, 参数为 map集合 和其对应的 key。注意:删除函数不返回任何值。
代码示例如下:
package mainimport "fmt"func main() { /* 创建 map */ cityMap := map[string] string {
"France":"Paris","Italy":"Rome","Japan":"Tokyo","India":"New Delhi"} fmt.Println("原始 map") /* 打印 map */ for country := range cityMap {
fmt.Println("Capital of",country,"is",cityMap[country]) } // 用delete函数删除元素 delete(cityMap,"France"); fmt.Println("Entry for France is deleted") fmt.Println("删除元素后 map") // 打印 输出map的值 for country := range cityMap {
fmt.Println("Capital of",country,"is",cityMap[country]) }}
输出结果:
原始 mapCapital of France is ParisCapital of Italy is RomeCapital of Japan is TokyoCapital of India is New DelhiEntry for France is deleted删除元素后 mapCapital of Italy is RomeCapital of Japan is TokyoCapital of India is New Delhi
我们可以通过key获取map中对应的value值。语法为:
map[key]
但是当key如果不存在的时候,我们会得到该value值类型的默认值,比如string类型得到空字符串,int类型得到0。但是程序不会报错。
所以我们可以使用 ok-idiom 获取值,可知道key/value是否存在,如下:
value, ok := map[key]
示例代码:
package mainimport ( "fmt")func main() {
m := make(map[string]int) m["a"] = 1 x, ok := m["b"] fmt.Println(x, ok) x, ok = m["a"] fmt.Println(x, ok)}
运行程序输出结果:
0 false1 true
与切片相似,映射是引用类型。当将映射分配给一个新变量时,它们都指向相同的内部数据结构。因此,一个的变化会反映另一个。
示例代码:
package mainimport ( "fmt")func main() { personSalary := map[string]int{
"steve": 12000, "jamie": 15000, } personSalary["mike"] = 9000 fmt.Println("Original person salary", personSalary) newPersonSalary := personSalary newPersonSalary["mike"] = 18000 fmt.Println("Person salary changed", personSalary)}
运行程序输出结果:
Original person salary map[steve:12000 jamie:15000 mike:9000] Person salary changed map[steve:12000 jamie:15000 mike:18000]
以上示例代码已归档到Github,如有需要欢迎下载学习交流:https://github.com/Scoefield/gokeyboardman/tree/main/mapdemo
本次有关Golang中的Map介绍就到这里啦,感谢您的阅读,如有疑问或意见请及时反馈给我们。
上一篇文章:
Golang并发控制之WaitGroup实现