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

什么是Java中的可重入锁_Java锁重入特性说明

可重入锁(ReentrantLock)是指同一个线程可以多次获取同一把锁,而不会因重复加锁导致自己被阻塞。这是它最核心的特性,也是区别于某些原始锁机制的关键所在。

可重入锁的本质是“线程绑定 + 计数器”

每个 ReentrantLock 内部维护两个关键信息:

当线程再次调用 lock() 时,锁会检查当前线程是否就是持有者——如果是,直接增加 state 并返回,不排队也不阻塞。

为什么需要可重入?解决嵌套调用死锁

在实际开发中,一个方法加了锁,内部又调用了另一个也需加锁的私有方法,如果锁不可重入,就会造成自己等自己,发生死锁。

公平性与非公平性影响获取顺序

ReentrantLock 支持两种构造方式:

注意:公平性只影响“未持有锁时的竞争”,不影响可重入逻辑本身。

使用时必须配对释放,推荐 try-finally 结构

由于 ReentrantLock 是显式锁,不会像 synchronized 那样自动释放,漏掉 unlock() 就会导致其他线程永久阻塞。

本文转载于:互联网 如有侵犯,请联系zhengruancom@outlook.com删除。
免责声明:正软商城发布此文仅为传递信息,不代表正软商城认同其观点或证实其描述。