Go语言基础教程:数据结构Map

在 Go 语言中,map 是一种用于存储键值对的集合,类似于其他编程语言中的字典(dictionary)或哈希表(hash table)。键可以是任何可比较类型,值可以是任何类型。map 是一种无序的集合,键和值之间的映射关系通过哈希函数来实现。

以下是使用 map 的一个示例,展示了如何创建、添加、删除以及操作键值对。

Go 复制代码
​
package main

import (
    "fmt"
    "maps"
)

func main() {

    // 创建一个空的map
    m := make(map[string]int)

    // 添加键值对
    m["k1"] = 7
    m["k2"] = 13

    fmt.Println("map:", m)

    // 访问map中的值
    v1 := m["k1"]
    fmt.Println("v1:", v1)

    // 尝试访问不存在的键
    v3 := m["k3"]
    fmt.Println("v3:", v3)

    // 查看map的长度
    fmt.Println("len:", len(m))

    // 删除键值对
    delete(m, "k2")
    fmt.Println("map:", m)

    // 清空map
    clear(m)
    fmt.Println("map:", m)

    // 检查键是否存在
    _, prs := m["k2"]
    fmt.Println("prs:", prs)

    // 使用字面量创建并初始化map
    n := map[string]int{"foo": 1, "bar": 2}
    fmt.Println("map:", n)

    // 比较两个map是否相等
    n2 := map[string]int{"foo": 1, "bar": 2}
    if maps.Equal(n, n2) {
        fmt.Println("n == n2")
    }
}

​
相关推荐
Albert Edison6 小时前
【Python】学生管理系统
开发语言·数据库·python
追随者永远是胜利者8 小时前
(LeetCode-Hot100)253. 会议室 II
java·算法·leetcode·go
宇木灵9 小时前
C语言基础-十、文件操作
c语言·开发语言·学习
追随者永远是胜利者9 小时前
(LeetCode-Hot100)207. 课程表
java·算法·leetcode·go
云泽8089 小时前
C++ 多态入门:虚函数、重写、虚析构及 override/final 实战指南(附腾讯面试题)
开发语言·c++
yanghuashuiyue10 小时前
lambda+sealed+record
java·开发语言
yzx99101311 小时前
Python数据结构入门指南:从基础到实践
开发语言·数据结构·python
衍生星球11 小时前
【JSP程序设计】Servlet对象 — page对象
java·开发语言·servlet·jsp·jsp程序设计
扶苏瑾11 小时前
线程安全问题的产生原因与解决方案
java·开发语言·jvm
小小小米粒12 小时前
函数式接口 + Lambda = 方法逻辑的 “插拔式解耦”
开发语言·python·算法