ReadWriteLock通过分离读写锁提升并发性能,允许多线程并发读、独占写,适用于读多写少场景。

在Java中,ReadWriteLock 是一种比普通互斥锁更灵活的同步机制,适用于读多写少的场景。它允许多个线程同时读取共享资源,但写操作是独占的,保证了数据一致性。核心实现类是 ReentrantReadWriteLock。
ReadWriteLock 基本概念
ReadWriteLock 接口维护了一对相关的锁:
- 读锁(Read Lock):多个线程可以同时获取,用于读操作。
- 写锁(Write Lock):只能由一个线程持有,且此时其他读线程也无法进入,用于写操作。
这种机制提高了并发性能,特别是在频繁读取、较少修改的场景下。
使用 ReentrantReadWriteLock 的基本步骤
以下是使用 ReadWriteLock 的典型方式:
立即学习“Java免费学习笔记(深入)”;
import java.util.concurrent.locks.ReadWriteLock;
import java.util.concurrent.locks.ReentrantReadWriteLock;
public class SharedData {
private final ReadWriteLock lock = new ReentrantReadWriteLock();
private String data = "初始数据";
// 读操作
public String read() {
lock.readLock().lock(); // 获取读锁
try {
System.out.println("读取数据: " + data);
return data;
} finally {
lock.readLock().unlock(); // 释放读锁
}
}
// 写操作
public void write(String newData) {
lock.writeLock().lock(); // 获取写锁
try {
System.out.println("写入数据: " + newData);
data = newData;
} finally {
lock.writeLock().unlock(); // 释放写锁
}
}
}
读写锁的使用注意事项
虽然 ReadWriteLock 提供了更高的并发性,但使用时需注意以下几点:
- 锁必须配对使用:每次 lock() 必须对应一个 unlock(),建议始终放在 try-finally 块中。
- 写锁可降级为读锁:持有写锁的线程可以再获取读锁,然后先释放写锁,保持读锁,实现“锁降级”。但不能反过来升级。
- 公平性选择:ReentrantReadWriteLock 构造函数支持传入 boolean 参数设置是否公平。公平模式下线程按请求顺序获取锁,避免饥饿,但吞吐量可能降低。
- 重入性:同一个线程可重复获取读锁或写锁(写锁已持有时)。
适用场景与性能考虑
ReadWriteLock 最适合以下情况:
- 读操作远多于写操作。
- 读取过程耗时较长,希望允许多个读并发执行。
- 写操作需要完全独占访问,防止脏读或不一致状态。
但如果写操作频繁,或读写比例接近,ReadWriteLock 可能不如 synchronized 或 ReentrantLock 高效,因为其内部管理更复杂。
基本上就这些。正确使用 ReadWriteLock 能显著提升读密集型应用的并发能力。关键在于理解读写之间的互斥规则,并确保锁的获取和释放逻辑严谨。不复杂但容易忽略细节。










