public class ReentrantReadWriteLock
implements ReadWriteLock, java.io.Serializable
这是一个读写锁, 其意义在于读和写操作时分别采用不同的并发策略, 即读操作只加写锁, 写操作加读锁和写锁, 可以减少一些加锁的开销.
容易理解, 读写锁是冲突的; 同一时间可以有多个线程持有读锁, 但同一时间只能有一个线程持有写锁.
这个类中的静态类ReadLock
和WriteLock
作为读写操作的实际操作者.
ReadWriteLock
ReentrantReadWriteLock实现了这个接口
public interface ReadWriteLock {
Lock readLock();
Lock writeLock();
}
虽然文档中的内容超长但是感觉没什么可说的, 我又没有必要自己写一个读写锁...
ReentrantReadWriteLock的构造方法和对象方法
- 构造方法
和ReentrantLock相同, 设置锁的公平性
public ReentrantReadWriteLock()
public ReentrantReadWriteLock(boolean fair)
- 对象方法
注意, 其中有些方法和ReentrantLock中方法重名, 但意义是不同的;
(注意注释中"请求"和"持有"的区别)
//表示请求读或写锁的线程
final int getQueueLength()
final boolean hasQueuedThread(Thread thread)
final boolean hasQueuedThreads()
//根据Condition, 请求写锁的线程数
int getWaitQueueLength(Condition condition)
boolean hasWaiters(Condition condition)
final boolean isFair()
//获取持有读锁的线程数
int getReadLockCount()
//获取当前线程中持有读锁的个数(即重入锁的个数)
int getReadHoldCount()
//获取当前线程中持有写锁的个数
int getWriteHoldCount()
boolean isWriteLocked()
boolean isWriteLockedByCurrentThread()
//获取读写锁中的ReadLock或者WriteLock
ReentrantReadWriteLock.ReadLock readLock()
ReentrantReadWriteLock.WriteLock writeLock()
//表示读锁和写锁的调用个数, 即[Write locks = w, Read locks = r]
String toString()
ReentrantReadWriteLock的静态类
上面已经提到, 有2个public的静态类: ReadLock
和WriteLock
. 虽然是public的, 但是我们使用的时候应该还是用readLock()
和writeLock()
方法获取吧, 那为什么要设为public呢...?
public static class ReadLock implements Lock, java.io.Serializable;
public static class WriteLock implements Lock, java.io.Serializable;
这两个类只继承了Lock中的方法, 没有添加新的方法, 因此不再说明; 了解读锁和写锁的意义, 即可合理地使用这个类.
网友评论