【go】map基础操作

Go语言中的map是一种无序的键值对集合,也被称为哈希表或字典,它使用哈希算法实现,可以高效地进行插入、查找和删除操作。以下是Go语言中map的主要用法及注意事项:


一、声明和初始化

  1. 声明map
    使用map[KeyType]ValueType形式声明map,其中KeyType是键的类型,ValueType是值的类型。例如:

    go 复制代码
    var m map[string]int

    此时mnil,必须初始化后才能使用。

  2. 初始化map

    • 使用make函数初始化:

      go 复制代码
      m := make(map[string]int)
    • 或直接赋值初始化:

      go 复制代码
      m := map[string]int{"one": 1, "two": 2}

    初始化后,map才能进行键值对操作。


二、基本操作

  1. 添加或修改键值对
    直接通过键赋值即可,若键不存在则添加,若键存在则更新值:

    go 复制代码
    m["three"] = 3
  2. 获取值
    通过键获取值,并返回一个布尔值表示键是否存在:

    go 复制代码
    value, ok := m["one"]
    if ok {
        fmt.Println("Value:", value)
    }
  3. 删除键值对
    使用delete函数删除指定键:

    go 复制代码
    delete(m, "two")
  4. 遍历map
    使用for range遍历map,注意遍历顺序是无序的:

    go 复制代码
    for key, value := range m {
        fmt.Println(key, value)
    }

三、注意事项

  1. 键的类型限制
    map的键必须是可比较的类型(如intstring等),不能为切片、map或函数等引用类型,否则编译会报错。
  2. 无序性
    map是无序的,每次遍历的顺序可能不同。如果需要有序遍历,需手动对键排序。
  3. 引用类型
    map是引用类型,赋值或作为函数参数传递时,操作的是同一个底层数据结构。
  4. 并发安全
    Go的map不是并发安全的,若需在多个goroutine中操作,需加锁或使用sync.Map

四、示例代码

go 复制代码
package main
import "fmt"
func main() {
    // 初始化map
    m := make(map[string]int)
    m["one"] = 1
    m["two"] = 2
    // 遍历map
    for key, value := range m {
        fmt.Println(key, value)
    }
    // 删除键值对
    delete(m, "two")
    // 检查键是否存在
    if value, ok := m["one"]; ok {
        fmt.Println("Value of 'one':", value)
    }
}

五、总结

Go语言的map是一种高效的键值对存储结构,适用于需要快速查找、插入和删除的场景。使用时需注意键的类型限制、无序性以及并发安全问题。通过合理声明、初始化和操作,可以充分发挥map的优势。

实战应用:排序

在Go语言中,map本身是无序的,无法直接对键值对进行排序。但可以通过将map的键或值提取到切片中,对切片进行排序,再按排序后的顺序遍历map,从而实现有序输出。

一、排序的基本步骤

  1. 提取键或值到切片
    将map的键或值存储到一个切片中,以便后续排序操作。
  2. 对切片排序
    使用sort包对切片进行排序。例如,按键排序时,可对键切片调用sort.Strings()或sort.Ints()等函数。
  3. 按排序后的顺序遍历map
    遍历排序后的切片,通过切片中的键或值访问map,从而实现有序输出。

二、示例代码

以下是一个按键排序的示例代码:

go 复制代码
package main
import (
	"fmt"
	"sort"
)
func main() {
	// 初始化map
	m := map[string]int{"banana": 2, "apple": 1, "orange": 3}
	// 提取键到切片
	keys := make([]string, 0, len(m))
	for key := range m {
		keys = append(keys, key)
	}
	// 对键切片排序
	sort.Strings(keys)
	// 按排序后的键遍历map
	for _, key := range keys {
		fmt.Printf("%s: %d\n", key, m[key])
	}
}

运行结果可能如下:

复制代码
apple: 1
banana: 2
orange: 3

三、注意事项

  1. 无序性
    Go语言的map默认是无序的,每次遍历map时输出的顺序可能不同。
  2. 排序范围
    排序操作仅针对切片,map本身不会被修改。排序后的顺序仅用于遍历输出。
  3. 按值排序
    如果需要按值排序,可以将键值对存储为结构体切片,并对结构体切片进行排序。
    通过以上方法,可以灵活实现对map键值对的排序需求。
相关推荐
小年糕是糕手16 小时前
【数据结构】算法复杂度
c语言·开发语言·数据结构·学习·算法·leetcode·排序算法
JAVA学习通16 小时前
微服务项目->在线oj系统(Java-Spring)--C端用户(超详细)
java·开发语言·spring
数据知道16 小时前
Go基础:Go语言ORM框架GORM详解
开发语言·jvm·后端·golang·go语言
计算机毕业设计小帅16 小时前
【2026计算机毕业设计】基于jsp的毕业论文管理系统
java·开发语言·毕业设计·课程设计
明天会有多晴朗16 小时前
深度剖析 C++ 之内存管理篇
c语言·开发语言·c++
potato_may17 小时前
C语言第3讲:分支和循环(上)—— 程序的“决策”与“重复”之旅
c语言·开发语言
kalvin_y_liu17 小时前
【MES架构师与C#高级工程师(设备控制方向)两大职业路径的技术】
开发语言·职场和发展·c#·mes
xxxxxxllllllshi17 小时前
Java 代理模式深度解析:从静态到动态,从原理到实战
java·开发语言·笔记·算法·代理模式
计算机毕业设计指导17 小时前
从零开始构建HIDS主机入侵检测系统:Python Flask全栈开发实战
开发语言·python·flask
步行cgn18 小时前
SqlSessionFactory 的作用
java·开发语言