[concurrent-map]-并发map在go中的使用

happlyfox · · 573 次点击 · · 开始浏览    
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

> 作者:三十三重天 > > 博客:http://www.zhouhuibo.club > > 通过学习和分享的过程,将自己工作中的问题和技术总结输出,希望菜鸟和老鸟都能通过自己的文章收获新的知识,并付诸实施。 ## 引言 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上读到更多,[这里](https://github.com/golang/go/issues/21035) and [这里](https://stackoverflow.com/questions/11063473/map-with-concurrent-access) ***译注:`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"添加个人微信,勾搭作者,欢迎来聊^-^。

有疑问加站长微信联系(非本文作者))

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

573 次点击  ∙  1 赞  
加入收藏 微博
暂无回复
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传