Go - 使用 sync.Map 来解决 map 的并发操作问题

简介: Go - 使用 sync.Map 来解决 map 的并发操作问题

文章目录:

  • 前言
  • map 并发操作出现问题
  • sync.Map 解决并发操作问题
  • 计算 map 长度
  • 计算 sync.Map 长度
  • 小结
  • 推荐阅读


前言

Golangmap 不是并发安全的,自 1.9 才引入了 sync.Mapsync.Map 的引入确实解决了 map 的并发安全问题,不过 sync.Map 却没有实现 len() 函数,如果想要计算 sync.Map 的长度,稍微有点麻烦,需要使用 Range 函数。

map 并发操作出现问题

func main() {
 demo := make(map[int]int)
 go func() {
  for j := 0; j < 1000; j++ {
   demo[j] = j
  }
 }()
 go func() {
  for j := 0; j < 1000; j++ {
   fmt.Println(demo[j])
  }
 }()
 time.Sleep(time.Second * 1)
}

执行输出:

fatal error: concurrent map read and map write

sync.Map 解决并发操作问题

func main() {
 demo := sync.Map{}
 go func() {
  for j := 0; j < 1000; j++ {
   demo.Store(j, j)
  }
 }()
 go func() {
  for j := 0; j < 1000; j++ {
   fmt.Println(demo.Load(j))
  }
 }()
 time.Sleep(time.Second * 1)
}

执行输出:

<nil> false
1 true
...
999 true

计算 map 长度

func main() {
 demo := make(map[int]int)
 for j := 0; j < 1000; j++ {
  demo[j] = j
 }
 fmt.Println("len of demo:", len(demo))
}

执行输出:

len of demo: 1000

计算 sync.Map 长度

func main() {
 demo := sync.Map{}
 
 for j := 0; j < 1000; j++ {
  demo.Store(j, j)
 }
 lens := 0
 demo.Range(func(key, value interface{}) bool {
  lens++
  return true
 })
 fmt.Println("len of demo:", lens)
}

执行输出:

len of demo: 1000

小结

  1. Load 加载 key 数据
  2. Store 更新或新增 key 数据
  3. Delete 删除 key 数据
  4. Range 遍历数据
  5. LoadOrStore 如果存在 key 数据则返回,反之则设置
  6. LoadAndDelete 如果存在 key 数据则删除

以上,希望对你能够有所帮助。

推荐阅读

目录
相关文章
|
26天前
|
Go
go语言中遍历映射(map)
go语言中遍历映射(map)
42 8
|
18天前
|
Go
go语言for遍历映射(map)
go语言for遍历映射(map)
29 12
|
22天前
|
存储 Go
go语言 遍历映射(map)
go语言 遍历映射(map)
33 2
|
29天前
|
存储 负载均衡 监控
如何利用Go语言的高效性、并发支持、简洁性和跨平台性等优势,通过合理设计架构、实现负载均衡、构建容错机制、建立监控体系、优化数据存储及实施服务治理等步骤,打造稳定可靠的服务架构。
在数字化时代,构建高可靠性服务架构至关重要。本文探讨了如何利用Go语言的高效性、并发支持、简洁性和跨平台性等优势,通过合理设计架构、实现负载均衡、构建容错机制、建立监控体系、优化数据存储及实施服务治理等步骤,打造稳定可靠的服务架构。
32 1
|
1月前
|
Go 调度 开发者
探索Go语言中的并发模式:goroutine与channel
在本文中,我们将深入探讨Go语言中的核心并发特性——goroutine和channel。不同于传统的并发模型,Go语言的并发机制以其简洁性和高效性著称。本文将通过实际代码示例,展示如何利用goroutine实现轻量级的并发执行,以及如何通过channel安全地在goroutine之间传递数据。摘要部分将概述这些概念,并提示读者本文将提供哪些具体的技术洞见。
|
2月前
|
Java 大数据 Go
Go语言:高效并发的编程新星
【10月更文挑战第21】Go语言:高效并发的编程新星
53 7
|
1月前
|
并行计算 安全 Go
Go语言的并发特性
【10月更文挑战第26天】Go语言的并发特性
18 1
|
2月前
|
存储 安全 Java
Map的并发处理,助你提升编程效率,代码更优雅高效。
【10月更文挑战第19天】Map使用技巧大公开:从选择合适的Map实现(如HashMap、TreeMap、LinkedHashMap)到利用Map的初始化、使用Map.Entry遍历、运用computeIfAbsent和computeIfPresent方法,再到Map的并发处理,助你提升编程效率,代码更优雅高效。
34 2
|
2月前
|
安全 Go 调度
探索Go语言的并发模式:协程与通道的协同作用
Go语言以其并发能力闻名于世,而协程(goroutine)和通道(channel)是实现并发的两大利器。本文将深入了解Go语言中协程的轻量级特性,探讨如何利用通道进行协程间的安全通信,并通过实际案例演示如何将这两者结合起来,构建高效且可靠的并发系统。
|
2月前
|
安全 Go 开发者
破译Go语言中的并发模式:从入门到精通
在这篇技术性文章中,我们将跳过常规的摘要模式,直接带你进入Go语言的并发世界。你将不会看到枯燥的介绍,而是一段代码的旅程,从Go的并发基础构建块(goroutine和channel)开始,到高级模式的实践应用,我们共同探索如何高效地使用Go来处理并发任务。准备好,让Go带你飞。