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

​
相关推荐
lly2024065 分钟前
CSS3 多媒体查询
开发语言
天***88961 小时前
js封装一个双精度算法实现
开发语言·前端·javascript
.小小陈.1 小时前
数据结构2:单链表
c语言·开发语言·数据结构·笔记·学习方法
Camel卡蒙1 小时前
数据结构——二叉搜索树Binary Search Tree(介绍、Java实现增删查改、中序遍历等)
java·开发语言·数据结构
Algebraaaaa1 小时前
什么是前端、后端与全栈开发,Qt属于什么?
开发语言·前端·qt
立志成为大牛的小牛1 小时前
数据结构——二十三、并查集的终极优化(王道408)
开发语言·数据结构·笔记·学习·程序人生·考研
纵有疾風起2 小时前
C++模版:模板初阶及STL简介
开发语言·c++·经验分享·开源
QT 小鲜肉2 小时前
【个人成长笔记】Qt Creator快捷键终极指南:从入门到精通
开发语言·c++·笔记·qt·学习·学习方法
子豪-中国机器人2 小时前
《C++ STL 基础入门》教案
java·开发语言
消失的旧时光-19432 小时前
ScheduledExecutorService
android·java·开发语言