go 使用 sync.RWMutex

使用 sync.RWMutex

简介

简述读写锁的使用,以及注意点

使用

在读操作的时候 加读锁, 在写操作的时候加写锁,

举例:

多个协程需要读取、写入的操作

go 复制代码
// 读操作
func reader(id int) {
	for {
		rwMutex.RLock()
		fmt.Printf("Reader %d: Reading sharedData: %d\n", id, sharedData)
		time.Sleep(time.Millisecond * time.Duration(rand.Intn(500)))
		rwMutex.RUnlock()
	}
}

// 写操作
func writer(id int) {
	for {
		newData := rand.Intn(100)
		rwMutex.Lock()
		fmt.Printf("Writer %d: Writing sharedData: %d\n", id, newData)
		sharedData = newData
		time.Sleep(time.Millisecond * time.Duration(rand.Intn(1000)))
		rwMutex.Unlock()
	}
}

func main() {
	// 启动多个读者和写者
	for i := 0; i < 3; i++ {
		go reader(i)
		go writer(i)
	}
	...
}

注意点

1、是否选用

读写锁适用于读取操作远远多于写入操作的场景,在读取锁被多个协程持有, 可以提供并发性能。 但并不是所有场景都适合读写锁的, 写锁会阻塞其他读锁写锁的情况, 比如在写多读少的情况下就不适合读写锁, 会限制并发性能。
2、避免死锁的发生

使用读锁的时候, 不要套用写锁
3、注意锁的范围粒度

(看 sync.Mutex的使用注意点)
4、做好开发设计、慎重考虑写锁情况

因为写锁会阻塞其他写锁、读锁的情况, 在选择使用读写锁后, 要考虑写锁的场景,确保写锁占用时间短
5、考虑其他同步机制

读写锁有时候并不能完全消除竞态条件, 不要局限锁。 要考虑其他同步机制。

其他同步机制有:waitGroup、 条件变量、原子操作、通道... ...
源码解读

相关推荐
牛奔11 小时前
Go语言中结构体转Map优雅实现
开发语言·后端·macos·golang·xcode
雨中散步撒哈拉16 小时前
22、做中学 | 高一下期 | Golang反射
开发语言·golang·状态模式
DICOM医学影像16 小时前
8. go语言从零实现以太坊响应端 - 查询区块链账户余额
golang·区块链·以太坊·web3.0·响应端·从零实现
Mr -老鬼18 小时前
Java、Go、Rust高并发时代“称雄”之战:场景适配与生态博弈
java·golang·rust
源代码•宸19 小时前
Golang原理剖析(map)
经验分享·后端·算法·golang·哈希算法·散列表·map
老蒋每日coding20 小时前
驾驭并发之力:Go语言构建高可用微服务完全指南
开发语言·微服务·golang
weixin1997010801620 小时前
安家 GO item_get - 获取安家详情数据接口对接全攻略:从入门到精通
java·大数据·python·golang
Logan Lie21 小时前
Go语言接口(interface)深度详解
开发语言·数据库·golang
林书笑忘书21 小时前
Go面试八股
java·面试·golang
molaifeng1 天前
Go 语言如何实现高性能网络 I/O:Netpoller 模型揭秘
开发语言·网络·golang