Lock特点
Lock接口提供了和synchronized关键字类似的同步功能,synchronized关键字只是隐式低获取锁,而lock拥有了锁获取和释放的可操作性、可中断的获取锁以及超时获取锁等同步特性
Lock使用
Lock lock = new ReentrantLock();
lock.lock();
try{
}finally{
lock.unlock();
}
在finally块中释放锁,目的是保证在获取到锁之后,最终能够被释放
不要将获取锁的过程中写在try块中,因为如果在获取锁(自定义锁的实现)时候发生了异常,异常抛出的同时,也会导致锁无故释放
特性 | 描述 |
1 .尝试非阻塞地获取锁 | 当前线程尝试获取锁,如果这一时刻锁没有被其他线程获取到,则成功获取锁,比如synchronized如果一个线程获取到锁,另一个线程要获取到锁,就必须阻塞等待,而lock不用 |
2. 能够被中断的获取锁 | 和synchronized不同,获取到锁的线程能够响应中断,当获取到lock锁的线程被中断,将抛出异常,并且释放锁 |
3.支持超时获取锁 | lock在指定的时间去获取锁,如果截止时间到了,仍然无法获取锁,则返回 |
重入锁ReentrantLock
能够支持一个线程对资源的重复加锁,这点synchronized也能够做到
public class GetLockAgain {
private Lock lock1 = new ReentrantLock();
private Lock lock2 = new ReentrantLock();
public void test (){
try{
lock1.lock();
System.out.println("获取到lock1");
lock2.lock();
System.out.println("获取到lock2");
}finally{
lock1.unlock();
lock2.unlock();
}
}
public static void main(String[] args) {
final GetLockAgain gla = new GetLockAgain();
gla.test();
}
}
输出: