ReadWriteLock
接口及其实现类ReentrantReadWriteLock
ReadWriteLock
接口ReadWriteLock
是一个接口,它定义了两个锁:读锁(Read Lock)和写锁(Write Lock)。- 读锁可以被多个线程同时持有,用于读取共享资源。当一个线程持有读锁时,其他线程也可以获取读锁来读取资源,只要没有线程持有写锁。
- 写锁是独占锁,当一个线程持有写锁时,其他线程不能获取读锁和写锁,直到写锁被释放。
ReentrantReadWriteLock
实现类ReentrantReadWriteLock
是ReadWriteLock
接口的一个实现类,它支持重入特性。- 它内部维护了读锁和写锁的状态,并且提供了获取和释放读锁、写锁的方法。
使用场景
- 读多写少的场景
- 在这种场景下,使用
ReadWriteLock
比ReentrantLock
更合适。例如,在一个缓存系统中,读取缓存数据的操作非常频繁,而更新缓存数据的操作相对较少。 - 当多个线程读取缓存数据时,它们可以同时获取读锁,不会互相阻塞,从而提高了并发性能。而当有线程要更新缓存数据时,它会获取写锁,此时其他线程的读锁和写锁请求都会被阻塞,直到写锁被释放。
- 如果使用
ReentrantLock
来保护缓存系统,那么每次读取操作都需要获取写锁,这会导致大量的线程阻塞,降低系统的并发性能。
- 在这种场景下,使用
示例代码
以下是一个使用ReentrantReadWriteLock
实现缓存系统的示例代码:
import java.util.HashMap;
import java.util.Map;
import java.util.concurrent.locks.ReadWriteLock;
import java.util.concurrent.locks.ReentrantReadWriteLock;
public class Cache {
private Map<String, String> cache = new HashMap<>();
private ReadWriteLock lock = new ReentrantReadWriteLock();
public String get(String key) {
lock.readLock().lock();
try {
return cache.get(key);
} finally {
lock.readLock().unlock();
}
}
public void put(String key, String value) {
lock.writeLock().lock();
try {
cache.put(key, value);
} finally {
lock.writeLock().unlock();
}
}
}
在这个示例中,Cache
类使用ReentrantReadWriteLock
来保护缓存数据。读取操作获取读锁,多个线程可以同时读取缓存数据;写入操作获取写锁,当有线程写入数据时,其他线程不能读取或写入缓存数据。
总结
ReadWriteLock
接口及其实现类ReentrantReadWriteLock
提供了一种更灵活的锁机制,在读多写少的场景下比ReentrantLock
更合适。通过使用读锁和写锁的分离,可以提高系统的并发性能。