读写锁(sync.RWMutex)允许多个读操作并发执行,但写操作独占资源。示例中,多个readData协程可同时持有读锁读取map,而writeData需获取写锁以确保数据安全;写锁会阻塞所有读操作,适用于读多写少场景,避免读饥饿与死锁需合理控制锁粒度。

在Go语言中,读写锁(Read-Write Mutex)用于解决多协程环境下对共享资源的并发访问问题。当多个协程只需要读取数据时,可以允许多个读操作同时进行;而写操作是互斥的,必须独占资源。Go标准库中的 sync.RWMutex 就是用来实现这种机制的。
读写锁区别于普通的互斥锁(sync.Mutex),它分为两种模式:
这种设计提升了高并发读场景下的性能,因为读操作不需要相互阻塞。
下面是一个典型的使用示例,展示多个协程并发读写一个共享的 map:
立即学习“go语言免费学习笔记(深入)”;
package main
<p>import (
"fmt"
"sync"
"time"
)</p><p>var (
data = make(map[string]int)
mu sync.RWMutex
wg sync.WaitGroup
)</p><p>func readData(key string) {
defer wg.Done()
mu.RLock() // 获取读锁
value := data[key]
mu.RUnlock() // 释放读锁
fmt.Printf("读取: %s = %d\n", key, value)
time.Sleep(10 * time.Millisecond)
}</p><p>func writeData(key string, value int) {
defer wg.Done()
mu.Lock() // 获取写锁
data[key] = value
mu.Unlock() // 释放写锁
fmt.Printf("写入: %s = %d\n", key, value)
time.Sleep(20 * time.Millisecond)
}</p><p>func main() {
// 启动多个读协程
for i := 0; i < 5; i++ {
wg.Add(1)
go readData("count")
}</p><pre class='brush:php;toolbar:false;'>// 启动写协程
wg.Add(1)
go writeData("count", 42)
// 再启动几个读
for i := 0; i < 3; i++ {
wg.Add(1)
go readData("count")
}
wg.Wait()}
在这个例子中:
读写锁适合以下情况:
不建议在频繁写入或写操作耗时很长的场景下使用,否则会导致“读饥饿”——即大量读请求长时间无法获取锁。
基本上就这些。通过 sync.RWMutex,你可以轻松实现高效的并发控制,尤其在读多写少的场景中表现优异。
以上就是Golang如何实现读写锁R/W Mutex的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号