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")
    }
}

​
相关推荐
lly20240610 分钟前
jEasyUI 设置排序指南
开发语言
一起努力啊~22 分钟前
算法刷题--长度最小的子数组
开发语言·数据结构·算法·leetcode
源代码•宸38 分钟前
Leetcode—39. 组合总和【中等】
经验分享·算法·leetcode·golang·sort·slices
还债大湿兄40 分钟前
huggingface.co 下载有些要给权限的模型 小记录
开发语言·前端·javascript
bkspiderx1 小时前
C++中的map容器:键值对的有序管理与高效检索
开发语言·c++·stl·map
Hard but lovely1 小时前
Linux: 线程同步-- 基于条件变量 &&生产消费模型
linux·开发语言·c++
汤姆yu1 小时前
基于python大数据的协同过滤音乐推荐系统
大数据·开发语言·python
爱学习的小道长1 小时前
Python Emoji库的使用教程
开发语言·python
Sammyyyyy1 小时前
Symfony AI 正式发布,PHP 原生 AI 时代开启
开发语言·人工智能·后端·php·symfony·servbay
C+-C资深大佬1 小时前
C++逻辑运算
开发语言·c++·算法