1.Lock接口及ReentrantLock实现,提供了和synchronized相同的互斥和内存可见性保证。
为什么需要显示锁?
因为内部锁不能中断正在等待获取锁的线程,并且锁失败时,需无限等待。
a) 可以轮询和可定时的锁请求。lock.tryLock()
b) 可中断的锁获取操作。lock.lockInterruptibly()
c) JDK6.0之前,ReentrantLock性能优于内部锁。
Lock的标准使用:
lock.lock();
try {
} finally {
lock.unlock();
}
2.ReadWriteLock (重入锁):可以被多个读者访问或者被一个写者访问。
public interface ReadWriteLock {
Lock readLock();
Lock writeLock();
}
3.void stateDependentMethod() throws InterruptedException {
synchronized(lock) {
while (!conditionPredicate())
lock.wait();
}
}
4.Condition (条件)。
why condition?
因为内部条件队列也存在一些缺陷,每个内部锁只能有一个与之关联的条件队列。