Go语言中map是引用类型,用于存储键值对,需初始化后使用。通过make或字面量创建,支持赋值、取值、判断存在和删除操作。遍历使用for range,顺序无序,需排序时可提取键到切片再排序。

在Go语言中,map是一种内置的引用类型,用于存储键值对(key-value pairs),它类似于其他语言中的哈希表或字典。map的键必须是可比较的类型(如字符串、整数等),而值可以是任意类型。
map的定义与初始化
Go中map的语法格式为:map[KeyType]ValueType,例如map[string]int表示键为字符串、值为整数的map。
map必须初始化后才能使用,否则其值为nil,向nil map写入数据会引发panic。可以通过以下方式创建和初始化map:
- 使用 make 函数:
m := make(map[string]int) - 使用字面量初始化:
m := map[string]string{"name": "Alice", "city": "Beijing"} - 声明一个nil map(仅声明不初始化):
var m map[string]int(此时不能赋值)
map的元素操作
map支持通过键直接读取、赋值和删除元素:
立即学习“go语言免费学习笔记(深入)”;
功能列表:底层程序与前台页面分离的效果,对页面的修改无需改动任何程序代码。完善的标签系统,支持自定义标签,公用标签,快捷标签,动态标签,静态标签等等,支持标签内的vbs语法,原则上运用这些标签可以制作出任何想要的页面效果。兼容原来的栏目系统,可以很方便的插入一个栏目或者一个栏目组到页面的任何位置。底层模版解析程序具有非常高的效率,稳定性和容错性,即使模版中有错误的标签也不会影响页面的显示。所有的标
- 赋值或更新:m["name"] = "Bob"
- 获取值:value := m["name"],如果键不存在,返回值类型的零值
- 判断键是否存在:
if val, ok := m["name"]; ok {
fmt.Println("存在:", val)
} - 删除键值对:delete(m, "name")
遍历map:使用for range
Go使用for range语法遍历map,遍历顺序是无序的(每次运行可能不同),不要依赖特定顺序。
基本遍历方式有三种:
- 只遍历键:
for key := range m {
fmt.Println(key)
} - 遍历键和值:
for key, value := range m {
fmt.Printf("%s: %v\n", key, value)
} - 只遍历值:
for _, value := range m {
fmt.Println(value)
}
如果需要有序遍历(如按键排序),可以将键提取到切片中,然后排序后再遍历:
m := map[string]int{"z": 3, "x": 1, "y": 2}var keys []string
for k := range m {
keys = append(keys, k)
}
sort.Strings(keys)
for _, k := range keys {
fmt.Printf("%s: %d\n", k, m[k])
}
基本上就这些。map在Go中非常常用,理解其初始化、安全访问和遍历方式是编写高效Go代码的基础。注意遍历时的无序性,避免假设固定的输出顺序。









