公平锁和非公平锁

公平锁:线程按照他们发出获取锁请求的顺序来获取锁,使用FIFO队列实现。

非公平锁:当获取锁的请求到达的时,如果锁状态为可用,则进行插队,直接获取锁,否则,将请求加入队列,队列中的请求依然遵循FIFO原则。

在激烈竞争锁的环境中,非公平锁比公平锁的性能更好,下图是使用公平锁和非公平锁对HashMap提供同步保护时的压测结果,非公平锁的吞吐量比公平锁高出2个量级。

原因:恢复一个挂起的线程与该线程真正执行之间存在严重的延迟,因为CPU的寄存器缓存和高速缓存都可能失效,需要重新载入数据。这时,如果将锁交给执行时间很短的任务,那么可以充分利用在被唤起线程真正开始执行之前的数据准备时间,从而提高了性能。从此处可以看出,当线程持有锁的时间比较长(执行任务需要的时间长)或者请求锁的平均时间间隔比较长,则应该使用公平锁。

synchronized和Lock默认使用非公平锁。

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值