Go - 使用 sync.Map 来解决 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 数据则删除

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

推荐阅读


新亮笔记
技术的深度和广度只能靠自己努力去发掘,谁也不能替你学习,在这里希望你能有所收获。

日拱一卒

2.9k 声望
1.2k 粉丝
0 条评论
推荐阅读
关于项目中 Repository 层的思考
维护这一层的开发者,可以称为 仓库管理员 ,当使用者需要查询数据的时候,需要告诉仓库管理员,由仓库管理员拿给他,至于仓库管理员从哪拿的数据,使用者无需关系。

新亮2阅读 1.8k评论 1

从零搭建 Node.js 企业级 Web 服务器(十五):总结与展望
总结截止到本章 “从零搭建 Node.js 企业级 Web 服务器” 主题共计 16 章内容就更新完毕了,回顾第零章曾写道:搭建一个 Node.js 企业级 Web 服务器并非难事,只是必须做好几个关键事项这几件必须做好的关键事项就...

乌柏木75阅读 7.1k评论 16

从零搭建 Node.js 企业级 Web 服务器(一):接口与分层
分层规范从本章起,正式进入企业级 Web 服务器核心内容。通常,一块完整的业务逻辑是由视图层、控制层、服务层、模型层共同定义与实现的,如下图:从上至下,抽象层次逐渐加深。从下至上,业务细节逐渐清晰。视图...

乌柏木45阅读 8.5k评论 6

从零搭建 Node.js 企业级 Web 服务器(二):校验
校验就是对输入条件的约束,避免无效的输入引起异常。Web 系统的用户输入主要为编辑与提交各类表单,一方面校验要做在编辑表单字段与提交的时候,另一方面接收表单的接口也要做足校验行为,通过前后端共同控制输...

乌柏木35阅读 6.7k评论 10

一文搞懂秒杀系统,欢迎参与开源,提交PR,提高竞争力。早日上岸,升职加薪。
前言秒杀和高并发是面试的高频考点,也是我们做电商项目必知必会的场景。欢迎大家参与我们的开源项目,提交PR,提高竞争力。早日上岸,升职加薪。知识点详解秒杀系统架构图秒杀流程图秒杀系统设计这篇文章一万多...

王中阳Go33阅读 2.5k评论 1

封面图
从零搭建 Node.js 企业级 Web 服务器(五):数据库访问
回顾 从零搭建 Node.js 企业级 Web 服务器(一):接口与分层,一块完整的业务逻辑是由视图层、控制层、服务层、模型层共同定义与实现的,控制层与服务层实现了业务处理过程,模型层定义了业务实体并以 对象-关系...

乌柏木34阅读 5k评论 9

从零搭建 Node.js 企业级 Web 服务器(十三):断点调试与性能分析
Node.js 官方提供了断点调试机制,出于安全性考虑默认为关闭状态,可以通过 node 参数 --inspect 或 --inspect-brk 开启,配合 IDE 能够非常方便地调试代码,本章就上一章已完成的项目 licg9999/nodejs-server-ex...

乌柏木31阅读 4.2k评论 9

日拱一卒

2.9k 声望
1.2k 粉丝
宣传栏