
在finally中释放锁
使用 ReentrantLock 时一定要记得释放锁,否则就会导致该锁一直被占用,其他使用该锁的线程则会永久的等待下去,所以我们在使用 ReentrantLock 时,一定要在finally中释放锁,这样就可以保证锁一定会被释放。
反例
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 | import java.util.concurrent.locks.ReentrantLock;
publicclass LockExample {
privatestaticfinal ReentrantLock lock = new ReentrantLock();
public static void main(String[] args) {
lock.lock();
System.out.println( "Hello,ReentrantLock." );
int number = 1 / 0;
lock.unlock();
System.out.println( "锁释放成功!" );
}
}
|
当出现异常时锁未被正常释放,这样就会导致其他使用该锁的线程永久的处于等待状态。
正例
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 | import java.util.concurrent.locks.ReentrantLock;
publicclass LockExample {
privatestaticfinal ReentrantLock lock = new ReentrantLock();
public static void main(String[] args) {
lock.lock();
try {
System.out.println( "Hello,ReentrantLock." );
int number = 1 / 0;
} finally {
lock.unlock();
System.out.println( "锁释放成功!" );
}
}
}
|
虽然方法中出现了异常情况,但并不影响 ReentrantLock 锁的释放操作,这样其他使用此锁的线程就可以正常获取并运行了。
以上就是Java ReentrantLock中容易踩到的坑,希望对大家有所帮助。更多精彩内容分享:头条