ReentrantLock提供比synchronized更灵活的线程控制,支持公平锁、可中断等待和超时获取锁;通过lock()加锁,必须在finally中unlock()释放锁以避免死锁;tryLock()实现非阻塞或限时获取锁,提升并发性能;lockInterruptibly()允许等待线程响应中断,适用于可取消操作场景。

在Java中,ReentrantLock 是一种可重入的显式锁,提供了比synchronized更灵活的线程控制机制。它位于 java.util.concurrent.locks 包中,支持公平锁与非公平锁、可中断等待、超时获取锁等高级功能。
使用 Reentrant7Lock 的核心是手动加锁和释放锁。必须确保在 finally 块中释放锁,防止死锁。
示例代码:
import java.util.concurrent.locks.ReentrantLock;
public class Counter {
private int count = 0;
private final ReentrantLock lock = new ReentrantLock();
public void increment() {
lock.lock(); // 获取锁
try {
count++;
} finally {
lock.unlock(); // 保证锁一定被释放
}
}
public int getCount() {
lock.lock();
try {
return count;
} finally {
lock.unlock();
}
}
}
显式锁不会像 synchronized 那样自动释放。如果临界区发生异常且未释放锁,其他线程将永久阻塞。
立即学习“Java免费学习笔记(深入)”;
正确的做法是在 try 块前加锁,finally 中解锁,确保即使抛出异常也能释放锁。
ReentrantLock 支持非阻塞获取锁,适用于避免死锁或限时等待的场景。
常用方法:
示例:
if (lock.tryLock()) {
try {
// 执行操作
} finally {
lock.unlock();
}
} else {
// 锁被占用,执行备用逻辑
}
当线程在等待进入临界区时,可以响应中断,避免无限等待。
适用于需要取消任务的场景。
public void interruptibleMethod() throws InterruptedException {
lock.lockInterruptibly(); // 可中断地获取锁
try {
// 临界区操作
} finally {
lock.unlock();
}
}
基本上就这些。ReentrantLock 提供了对锁行为的精细控制,但也要承担手动管理的责任。只要记得始终在 finally 中 unlock,合理使用 tryLock 和中断机制,就能写出高效安全的并发代码。
以上就是如何在Java中使用ReentrantLock实现显式锁的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号