可重入锁允许同一线程多次获取同一把锁而不阻塞,其核心是“线程绑定+计数器”机制,通过state值记录加锁次数、持有线程引用确保仅该线程可重入;用于避免嵌套调用死锁,支持公平/非公平模式,且必须配合try-finally确保unlock。

可重入锁(ReentrantLock)是指同一个线程可以多次获取同一把锁,而不会因重复加锁导致自己被阻塞。这是它最核心的特性,也是区别于某些原始锁机制的关键所在。
每个 ReentrantLock 内部维护两个关键信息:
当线程再次调用 lock() 时,锁会检查当前线程是否就是持有者——如果是,直接增加 state 并返回,不排队也不阻塞。
在实际开发中,一个方法加了锁,内部又调用了另一个也需加锁的私有方法,如果锁不可重入,就会造成自己等自己,发生死锁。
立即学习“Java免费学习笔记(深入)”;
public void doWork() { lock.lock(); try { process(); } finally { lock.unlock(); } }
process() 内部又写了 lock.lock() —— 可重入锁允许这种写法安全执行synchronized 的行为一致,但 ReentrantLock 提供了更细粒度的控制能力ReentrantLock 支持两种构造方式:
lock() 的先后顺序排队,避免饥饿,但性能略低注意:公平性只影响“未持有锁时的竞争”,不影响可重入逻辑本身。
由于 ReentrantLock 是显式锁,不会像 synchronized 那样自动释放,漏掉 unlock() 就会导致其他线程永久阻塞。
finally 块中调用 unlock()
以上就是什么是Java中的可重入锁_Java锁重入特性说明的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号