担心一些资源可能无法正常释放,使用finally释放资源
释放死锁,使用这个接口,这样就不会产生死锁
Lock lock=new ReentrainLock();
lock.lock();
try{
}finally{
lock.unlock();
}
支持重新进入的锁,表示该锁能够支持一个线程对资源的重复加锁。除此之外,该锁还支持获取锁时的公平和非公平性选择。
在类似于递归等反复调用的场景中使用
只适用于读多写少的场景
特性 | 说明 |
公平性选择 | 支持非公平和公平的锁获取方式,吞吐量还是非公平优先于公平 |
重进入 | 支持重进入,以读写线程为例:该线程在获取了读锁以后,能够再次获取读锁。而写线程在获取了写锁之后能够再次获取写锁,同时也可以获取读锁 |
锁降级 | 遵循获取写锁,获取读锁再次释放写锁的次序,写锁能够降级成为读锁 |
//设置key对应的value,并返回旧的value
public static final Object put(String key,Object value){
w.lock();
try{
return map.put(key,value);
}finally{
w.unlock();
}
}
//清空所有内容
public static final void clear(){
w.lock();
try{
map.clear();
}finally{
w.unclock();
}
}
6.锁降级的过程中不会释放锁
7.调用Condition的await()方法(或者以await开头的方法)会使当前线程进入等待队列并释放锁,同时线程状态变为等待状态。当从await()方法返回时,当前线程一定获取了Condition相关的锁