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


本文摘自网络,作者,侵删。

作者:三十三重天

首发 | 我的博客

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

引言

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


本文来自:简书

感谢作者:HapplyFox

查看原文:[concurrent-map]-并发map在go中的使用

相关阅读 >>

Go-锁机制

前 言

基于原论文,我实现了一个更全面的布谷鸟过滤器

Golang fyne 使用中文并打包进二进制文件

Golang导出csv乱码解决方法

聊聊storagetapper的pipe

2021-04-19

Go写的第一个小程序记账系统,来啦

Golang 能不能打包为 dll ?

Golang基础数据类型字符串

更多相关阅读请进入《Go》频道 >>




打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...