Go语言之Map 的基本操作-《Go语言实战指南》

map 是 Go 语言中内建的哈希表(hash table)数据结构,用于存储无序的 key-value 键值对。Go 的 map 使用方便、功能强大,是日常开发中的重要工具。


一、map 的定义

基本语法:
复制代码
var m map[keyType]valueType

keyType 可比较类型(如:int、string、bool),valueType 可为任意类型。

示例:
复制代码
var scores map[string]int

此时 scoresnil,尚未分配内存,不能直接赋值。


二、初始化 map

使用 make 函数:
复制代码
scores := make(map[string]int)

或指定容量(底层做预分配优化):

复制代码
scores := make(map[string]int, 10)
使用字面量:
复制代码
scores := map[string]int{
    "Alice": 90,
    "Bob":   85,
}

三、添加和更新键值对

直接通过 map[key] = value 语法添加或更新:

复制代码
scores["Charlie"] = 95  // 添加新键值
scores["Alice"] = 99    // 更新已有键值

四、访问 map 中的值

复制代码
fmt.Println(scores["Alice"]) // 输出 99

如果 key 不存在,返回值类型的零值:

复制代码
fmt.Println(scores["Unknown"]) // 输出 0(因为值类型是 int)

五、判断 key 是否存在

Go 提供双赋值语法判断键是否存在:

复制代码
value, ok := scores["Bob"]
if ok {
    fmt.Println("Bob's score is", value)
} else {
    fmt.Println("Bob not found")
}

六、删除键值对

使用 delete(map, key) 函数:

复制代码
delete(scores, "Charlie")

删除不存在的 key 不会报错,是安全操作。


七、遍历 map

使用 for-range 遍历键值对(无序):

复制代码
for name, score := range scores {
    fmt.Printf("%s: %d\n", name, score)
}

遍历顺序是随机的,每次运行可能都不同。


八、map 是引用类型

赋值或传参时,多个变量指向同一个底层数据:

复制代码
m1 := map[string]int{"a": 1}
m2 := m1
m2["a"] = 100
fmt.Println(m1["a"]) // 输出 100

九、map 不支持的操作

  • • 不能使用 == 比较两个 map(只能与 nil 比较)
  • • 不支持 len(map) 修改元素数量,但可以用 len(m) 获取当前键数量
  • • map 的 key 必须是可比较类型,如不能使用切片、map、函数作为 key

十、总结

操作 方法
创建 map make(map[KeyType]ValueType)
添加/更新 m[key] = value
读取 value := m[key]
判断存在 value, ok := m[key]
删除键 delete(m, key)
遍历 for k, v := range m

掌握这些基础操作后,你就能高效地在 Go 中使用 map 来组织和处理键值数据。

相关推荐
洛森唛1 分钟前
ElasticSearch查询语句Query String详解:从入门到精通
后端·elasticsearch
用户8307196840829 分钟前
Spring Boot 集成 RabbitMQ :8 个最佳实践,杜绝消息丢失与队列阻塞
spring boot·后端·rabbitmq
小兔崽子去哪了20 分钟前
Java 自动化部署
java·后端
Selicens21 分钟前
git批量删除本地多余分支
前端·git·后端
哈密瓜的眉毛美25 分钟前
Java 基础补充:零基础学Java | Scanner 类详解
后端
ma_king26 分钟前
入门 java 和 数据库
java·数据库·后端
平平无奇的开发仔29 分钟前
Mybaitis 项目多模块多依赖xml加载classpath:和classpath*:的区别
后端
神奇小汤圆1 小时前
MySQL的10种高级SQL,性能飞升
后端
AI探索者1 小时前
LangGraph 人工干预:Human-in-the-loop 机制详解
后端
神奇小汤圆1 小时前
Java并发核心:你以为AQS很复杂?无非是"两个队列"和"一个状态"
后端