【Java面试】ReentrantLock 是如何实现锁公平和非公平性的 ?

一个工作了3年的程序员竟然连这个问题都回答不上?

Hi,大家好,我是Mic。

今天分享一道3年经验,频率较高的面试题。

“ReentrantLock是如何实现锁的公平和非公平性的”?

下面看看普通人和高手对这个问题的回答

需要高手面试文档(附赠大厂内部十万字面试文档)或者有不懂的技术面试题想咨询的小伙伴可以私信我发送【Mic】或者评论区留言。

普通人:

ReentrantLock 去实现公平锁和非公平锁。

就是我们在调用那个Lock方法去竞争锁的时候啊,它会就如果是非公平锁的话,它会直接去抢占那个锁资源。

然后如果是公平锁的话它会去有一个判断,它会去判断那个阻塞队列里面是不是有线程在排队,如果有人在排队的话它会,它就不能去抢占锁,它会加入到那个队列的尾部然后去进行等待。

高手:

好的。

我先解释一下个公平和非公平的概念。

公平,指的是竞争锁资源的线程,严格按照请求顺序来分配锁。

非公平,表示竞争锁资源的线程,允许插队来抢占锁资源。

ReentrantLock默认采用了非公平锁的策略来实现锁的竞争逻辑。

其次,ReentrantLock内部使用了AQS来实现锁资源的竞争,没有竞争到锁资源的线程,会加入到AQS的同步队列里面,这个队列是一个FIFO的双向链表。

在这样的一个背景下,公平锁的实现方式就是,线程在竞争锁资源的时候判断AQS同步队列里面有没有等待的线程。

如果有,就加入到队列的尾部等待。

而非公平锁的实现方式,就是不管队列里面有没有线程等待,它都会先去尝试抢占锁资源,如果抢不到,再加入到

AQS同步队列等待。

ReentrantLock和Synchronized默认都是非公平锁的策略,之所以要这么设计,我认为还是考虑到了性能这个方面的原因。

因为一个竞争锁的线程如果按照公平的策略去阻塞等待,同时AQS再把等待队列里面的线程唤醒,这里会涉及到内核态

的切换,对性能的影响比较大。

如果是非公平策略,当前线程正好在上一个线程释放锁的临界点抢占到了锁,就意味着这个线程不需要切换到内核态,

虽然对原本应该要被唤醒的线程不公平,但是提升了锁竞争的性能。

以上就是我对这个问题的理解。

总结

这个问题,主要考察求职者的基础知识。

别小看这些基础,在实际开发过程中,不管是对代码的稳定性

还是对性能的影响都是非常大的。

这也是大厂面试必然会问基础问题的原因之一。

喜欢我的作品的朋友,记得点赞收藏加关注

需要高手面试文档(附赠大厂内部十万字面试文档)或者有不懂的技术面试题想咨询的小伙伴可以扫描下方二维码

↓↓↓↓↓↓↓↓↓↓↓↓↓↓

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

跟着Mic学架构

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值