go 使用 sync.RWMutex
2024-01-02 15:14:17
简介
简述读写锁的使用,以及注意点
使用
在读操作的时候 加读锁, 在写操作的时候加写锁,
举例:
多个协程需要读取、写入的操作
// 读操作
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、 条件变量、原子操作、通道… …
源码解读
文章来源:https://blog.csdn.net/qq_40484416/article/details/135336178
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!