Golang syncMap 详解

Golang sync.Map 详解

在 Golang 中,sync.Map 是一个并发安全的 Map 实现,可以在多个 Goroutine 中安全地读写 Map。本文将对 sync.Map 进行详细的介绍,包括创建、初始化、添加元素、删除元素、遍历等操作,并提供相应的示例代码。

sync.Map 的创建和初始化

在 Golang 中,可以使用 sync.Map{} 字面量来创建一个空的 sync.Map。例如,以下是一个字符串到整数的 sync.Map 的创建和初始化示例:

go 复制代码
// 创建一个字符串到整数的 sync.Map
var m sync.Map

// 初始化 sync.Map
m.Store("one", 1)
m.Store("two", 2)
m.Store("three", 3)

// 打印 sync.Map
m.Range(func(key, value interface{}) bool {
    fmt.Printf("key: %s, value: %d\n", key, value)
    return true
})

在上面的示例中,创建一个字符串到整数的 sync.Map,并使用 m.Store(key, value) 的方式来初始化 Map 中的元素。最后,使用 m.Range() 函数来遍历 Map 中的元素,并打印每个元素的 key 和 value。

sync.Map 的添加元素

在 Golang 中,可以使用 m.Store(key, value) 的方式来添加元素到 sync.Map 中。例如,以下是一个字符串到整数的 sync.Map 的添加元素示例:

go 复制代码
// 创建一个字符串到整数的 sync.Map
var m sync.Map

// 初始化 sync.Map
m.Store("one", 1)
m.Store("two", 2)
m.Store("three", 3)

// 在 sync.Map 中添加元素
m.Store("four", 4)

// 打印 sync.Map
m.Range(func(key, value interface{}) bool {
    fmt.Printf("key: %s, value: %d\n", key, value)
    return true
})

在上面的示例中,创建一个字符串到整数的 sync.Map,并使用 m.Store(key, value) 的方式来添加元素到 Map 中。然后使用 m.Store(key, value) 的方式在 Map 中添加一个元素。最后,使用 m.Range() 函数来遍历 Map 中的元素,并打印每个元素的 key 和 value。

sync.Map 的删除元素

在 Golang 中,可以使用 m.Delete(key) 函数来删除 sync.Map 中的元素。例如,以下是一个字符串到整数的 sync.Map 的删除元素示例:

go 复制代码
// 创建一个字符串到整数的 sync.Map
var m sync.Map

// 初始化 sync.Map
m.Store("one", 1)
m.Store("two", 2)
m.Store("three", 3)

// 删除 sync.Map 中的元素
m.Delete("two")

// 打印 sync.Map
m.Range(func(key, value interface{}) bool {
    fmt.Printf("key: %s, value: %d\n", key, value)
    return true
})

在上面的示例中,创建一个字符串到整数的 sync.Map,并使用 m.Store(key, value) 的方式来添加元素到 Map 中。然后使用 m.Delete(key) 函数删除 Map 中的一个元素。最后,使用 m.Range() 函数来遍历 Map 中的元素,并打印每个元素的 key 和 value。

sync.Map 的遍历

在 Golang 中,可以使用 m.Range() 函数来遍历 sync.Map 中的元素。例如,以下是一个字符串到整数的 sync.Map 的遍历示例:

go 复制代码
// 创建一个字符串到整数的 sync.Map
var m sync.Map

// 初始化 sync.Map
m.Store("one", 1)
m.Store("two", 2)
m.Store("three", 3)

// 遍历 sync.Map 中的元素
m.Range(func(key, value interface{}) bool {
    fmt.Printf("key: %s, value: %d\n", key, value)
    return true
})

在上面的示例中,创建一个字符串到整数的 sync.Map,并使用 m.Store(key, value) 的方式来添加元素到 Map 中。然后使用 m.Range() 函数遍历 Map 中的元素,并打印每个元素的 key 和 value。

总结

本文介绍了 Golang 中 sync.Map 的创建、初始化、添加元素、删除元素和遍历操作。相较普通的 Map,sync.Map 有以下几个优点:

  1. 并发安全:在多个 Goroutine 中读写 Map 时,使用 sync.Map 可以避免数据竞争的问题。
  2. 支持任意类型的 key 和 value:在传统的 Map 中,key 和 value 必须是具体的类型,而 sync.Map 可以支持任意类型的 key 和 value。
  3. 自动扩容:在传统的 Map 中,当 Map 中元素的数量超过了容量时,需要手动扩容。而 sync.Map 会自动扩容,无需手动干预。

需要注意的是,使用 sync.Map 时需要注意以下几点:

  1. sync.Map 中的元素是无序的。
  2. sync.Map 中的元素是以接口类型的形式存储的,因此在读取元素时需要进行类型断言。
  3. sync.Map 中的元素不支持 Range() 函数之外的并发访问。

总之,sync.Map 是 Golang 中非常实用的并发安全的 Map 实现,使用起来非常方便。希望本文可以帮助读者更加深入地了解 Golang sync.Map 的使用和实现。

相关推荐
苍何2 分钟前
一手实测 Claude Fable 5,手搓了个 Obsidian 的 Codex 插件
后端
swipe43 分钟前
做多轮对话 Agent,为什么我建议把短期记忆放到 Redis
后端·面试·llm
程序员黑豆1 小时前
AI全栈开发之Java:什么是JDK
前端·后端·ai编程
阿明在折腾2 小时前
从Canvas到AI模型:我在线工具站里的图片处理实战
前端·后端
tyung2 小时前
Go 手写 Wait-Free SPSC 无界队列:无 CAS、无锁、泛型节点池
数据结构·后端·go
Lucien3232 小时前
学完 Spring Boot 再看 FastAPI,我破防了
后端
小小龙学IT2 小时前
Go 语言后端开发:从并发模型到生产落地的工程实践
开发语言·后端·golang
程序员cxuan2 小时前
Agents.md 是什么
人工智能·后端·程序员
摇滚侠2 小时前
Java 零基础全套教程,类的加载过程与类加载器的理解,笔记 189
java·后端·intellij-idea
ServBay2 小时前
为什么我劝你不要在Mac上用Docker 进行本地 AI 开发
后端