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

​
相关推荐
特种加菲猫16 分钟前
从零开始手撕AVL树:详解插入、平衡因子更新与四种旋转
开发语言·c++
roman_日积跬步-终至千里23 分钟前
如何分析复杂架构:一套真正能落地的方法
java·开发语言·架构
geovindu26 分钟前
go: Semaphore Pattern
开发语言·后端·设计模式·golang·企业级信号量模式
Don.TIk34 分钟前
ChaperTwo-整合 SaToken 实现 JWT 登录功能
java·开发语言
yaoxin5211231 小时前
406. Java 文件操作基础 - 字符与二进制流
java·开发语言·python
江屿风1 小时前
C++OJ题经验总结(竞赛)1
开发语言·c++·笔记·算法
有点。2 小时前
C++(枚举法一练习题)
开发语言·c++·算法
审判长烧鸡2 小时前
【PHPer转Go】fmt vs log/slog
go·php