[Go] 使用读写锁对map资源进行安全处理
当需要有一个全局性的map集合资源进行增删改数据时,需要对该map资源增加读写锁,防止并发时出现安全问题
下面的类就是举例 , 属性中的Conns模拟存储一些资源,对这些资源进行并发的增加数据,使用写锁锁住资源,当读取是使用读锁锁住资源
package snet import "sync" import "errors" type ConnManger struct { Conns map[uint32]string ConnLock sync.RWMutex } func NewConnManger() *ConnManger { cm := &ConnManger{ Conns: make(map[uint32]string), } return cm } func (cm *ConnManger) Add(id uint32, value string) { cm.ConnLock.Lock() defer cm.ConnLock.Unlock() cm.Conns[id] = value } func (cm *ConnManger) Remove(id uint32) { cm.ConnLock.Lock() defer cm.ConnLock.Unlock() delete(cm.Conns, id) } func (cm *ConnManger) Get(id uint32) (string, error) { cm.ConnLock.RLock() defer cm.ConnLock.RUnlock() conn, ok := cm.Conns[id] if !ok { return "", errors.New("connmanager get conn error ") } return conn, nil } func (cm *ConnManger) Len() int { return len(cm.Conns) } func (cm *ConnManger) Clean() { cm.ConnLock.Lock() defer cm.ConnLock.Unlock() for key, _ := range cm.Conns { delete(cm.Conns, key) } }
使用时
package main import "single/snet" import "log" import "sync" import "strconv" func main() { cm:=snet.NewConnManger() var wg sync.WaitGroup for i:=0;i<10;i++{ go func(i uint32){ defer wg.Done() wg.Add(1) cm.Add(i,"连接"+strconv.Itoa(int(i))) }(uint32(i)) } wg.Wait() log.Println(cm.Len()) for key,value:=range cm.Conns{ log.Println(key,value) } cm.Clean() log.Println(cm.Len()) select{} }
十年开发经验程序员,离职全心创业中,历时三年开发出的产品《唯一客服系统》
一款基于Golang+Vue开发的在线客服系统,软件著作权编号:2021SR1462600。一套可私有化部署的网站在线客服系统,编译后的二进制文件可直接使用无需搭开发环境,下载zip解压即可,仅依赖MySQL数据库,是一个开箱即用的全渠道在线客服系统,致力于帮助广大开发者/公司快速部署整合私有化客服功能。
开源地址:唯一客服(开源学习版)
官网地址:唯一客服官网