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 的使用和实现。

相关推荐
ltl6 小时前
Transformer 整体架构:一张图看懂
后端
ltl6 小时前
Decoder 详解:为什么它天生适合生成
后端
ltl7 小时前
Encoder 详解:6 层堆叠到底在做什么
后端
程序员cxuan7 小时前
微信读书官方发了 skills,把我给秀麻了。
人工智能·后端·程序员
未若君雅裁8 小时前
Spring AOP、日志切面与声明式事务原理
java·后端·spring
zhangxingchao8 小时前
AI应用开发六:企业知识库
前端·人工智能·后端
红尘散仙9 小时前
一个 `#[uniffi::export]`,把 Rust 接进 React Native
前端·后端·rust
红尘散仙9 小时前
一行 `#[specta::specta]`,让 Tauri IPC 有类型
前端·后端·rust
XinZong11 小时前
OpenClaw 中最经典的 6 款skill,真正能进工作流的 skills
javascript·后端
zhangxingchao11 小时前
AI Agent 基础问题系统整理:从 LangChain、LangGraph、MCP 到 Agent 架构、记忆、工具调用与评估体系
前端·人工智能·后端