java中什么是公平锁,什么是非公平锁,有什么区别

公平锁和非公平锁是指在多线程环境下,线程获取锁的顺序和公平性的不同。

  1. 公平锁(Fair Lock):

    • 公平锁是指多个线程按照申请锁的顺序来获取锁,即按照线程的排队顺序获取锁资源。
    • 当一个线程释放锁时,等待时间最长的线程将获得锁的访问权。
    • 公平锁能够保证锁的获取是按照先来先得的原则,避免线程饥饿现象。
  2. 非公平锁(Nonfair Lock):

    • 非公平锁是指多个线程获取锁的顺序是不确定的,具体的选择是由线程调度器决定的。
    • 当一个线程释放锁时,任何一个等待的线程都有机会获取锁。
    • 非公平锁允许新来的线程获取锁,即使已经有其他线程在等待获取锁资源。

在Java中,synchronized关键字是非公平锁。当线程释放锁时,任何一个等待的线程都有机会获取锁,无法保证等待时间最长的线程优先获取锁。

而在Java的并发包(java.util.concurrent)中,ReentrantLock类可以实现公平锁和非公平锁。在创建ReentrantLock对象时,可以通过构造方法或参数指定锁的公平性。默认情况下,ReentrantLock是非公平锁,但可以通过构造方法的参数设置为公平锁。

公平锁会导致线程切换的开销增加,因为需要维护线程的等待队列。非公平锁的优点是吞吐量比较高,因为线程不需要排队等待锁的释放,可以直接抢占锁。但是非公平锁可能会导致某些线程长时间等待,产生线程饥饿的问题

选择公平锁还是非公平锁要根据具体的场景和需求来决定。如果对于线程获取锁的顺序要求较高,可以选择公平锁;如果追求更高的吞吐量,可以选择非公平锁。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

小小懒懒

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

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

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

打赏作者

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

抵扣说明:

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

余额充值