您现在的位置是:课程教程文章

聊聊Java ReentrantLock中容易踩到的坑

2023-12-13 23:41课程教程文章 人已围观


在finally中释放锁

使用 ReentrantLock 时一定要记得释放锁,否则就会导致该锁一直被占用,其他使用该锁的线程则会永久的等待下去,所以我们在使用 ReentrantLock 时,一定要在finally中释放锁,这样就可以保证锁一定会被释放。


反例

importjava.util.concurrent.locks.ReentrantLock;

publicclassLockExample{
//创建锁对象
privatestaticfinalReentrantLocklock=newReentrantLock();
publicstaticvoidmain(String[]args){
//加锁操作
lock.lock();
System.out.println("Hello,ReentrantLock.");
//此处会报异常,导致锁不能正常释放
intnumber=1/0;
//释放锁
lock.unlock();
System.out.println("锁释放成功!");
}
}

当出现异常时锁未被正常释放,这样就会导致其他使用该锁的线程永久的处于等待状态。


正例

importjava.util.concurrent.locks.ReentrantLock;

publicclassLockExample{
//创建锁对象
privatestaticfinalReentrantLocklock=newReentrantLock();
publicstaticvoidmain(String[]args){
//加锁操作
lock.lock();
try{
System.out.println("Hello,ReentrantLock.");
//此处会报异常
intnumber=1/0;
}finally{
//释放锁
lock.unlock();
System.out.println("锁释放成功!");
}
}
}

虽然方法中出现了异常情况,但并不影响 ReentrantLock 锁的释放操作,这样其他使用此锁的线程就可以正常获取并运行了。

以上就是Java ReentrantLock中容易踩到的坑,希望对大家有所帮助。更多精彩内容分享:头条

课程教程:聊聊Java ReentrantLock中容易踩到的坑

上一篇:常用6种顶级Python文本编辑器

下一篇:没有了

站点信息

  • 文章统计篇文章