golang的Map并发安全

原创
2021/03/16 09:22
阅读数 0

通过学习和分享的过程,将自己工作中的问题和技术总结输出,希望菜鸟和老鸟都能通过自己的文章收获新的知识,并付诸实施。

引言

Go语言原生的map类型并不支持并发读写。

在Go 1.9之前,go语言标准库中并没有实现并发map。在Go 1.9中,引入了sync.Map

concurrent-map的优势

concurrent-map提供了一种高性能的解决方案:通过对内部map进行分片,降低锁粒度,从而达到最少的锁等待时间(锁冲突)。

sync.Map与此concurrent-map有几个关键区别。

标准库中的sync.Map是专为append-only场景设计的。因此,如果您想将Map用于一个类似内存数据库,那么使用我们的版本可能会受益。

你可以在golang repo上读到更多,这里 and 这里 译注:sync.Map在读多写少性能比较好,否则并发性能很差

用法

go get "github.com/orcaman/concurrent-map"
import (
 "github.com/orcaman/concurrent-map"
)

示例

与原生的写法没什么太大区别

 // 创建一个新的 map.
 m := cmap.New()

 // 设置变量m一个键为“foo”值为“bar”键值对
 m.Set("foo""bar")

 // 从m中获取指定键值.
 if tmp, ok := m.Get("foo"); ok {
  bar := tmp.(string)
 }

 // 删除键为“foo”的项
 m.Remove("foo")

资源清单

https://github.com/orcaman/concurrent-map

END

欢迎关注公众号 程序员工具集 👍👍  致力于分享优秀的开源项目、学习资源 、常用工具

回复关键词“关注礼包”,送你一份最全的程序员技能图谱。

回复关键词"wx"添加个人微信,勾搭作者,欢迎来聊^-^。


本文分享自微信公众号 - 程序员工具集(rdtool)。
如有侵权,请联系 support@oschina.cn 删除。
本文参与“OSC源创计划”,欢迎正在阅读的你也加入,一起分享。

展开阅读全文
加载中
点击引领话题📣 发布并加入讨论🔥
0 评论
0 收藏
0
分享
返回顶部
顶部