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

​
相关推荐
代码中介商29 分钟前
C++左值与右值:核心判断法则详解
开发语言·c++
JAVA96534 分钟前
JAVA面试-并发篇 05-并发包AQS队列实现原理是什么
java·开发语言·面试
Halo_tjn1 小时前
反射与设计模式1
java·开发语言·算法
珊瑚里的鱼2 小时前
手撕单例模式中的饿汉模式和懒汉模式,懒汉模式还要再多加一个C++11版本的
开发语言·c++·单例模式
_不会dp不改名_2 小时前
python-opencv环境搭建
开发语言·python·opencv
HappyAcmen2 小时前
9.复盘API全套流程
开发语言·python
charlie1145141912 小时前
通用GUI编程技术——图形渲染实战(四十五)——D3D12资源与堆管理:从上传到驻留
开发语言·3d·图形渲染·win32
不会C语言的男孩2 小时前
C++ Primer 第12章:动态内存
开发语言·c++
踏着七彩祥云的小丑3 小时前
Go学习第1天:入门
开发语言·学习·golang·go
眠りたいです3 小时前
现代C++:C++17中的新库特性
开发语言·c++·c++20·c++17