公平锁与非公平锁,可重入锁与不可重入锁

本文介绍了公平锁与非公平锁的区别,探讨了它们的效率与线程饥饿问题。此外,还深入讨论了可重入锁的概念及其在防止死锁中的作用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

公平锁与非公平锁
公平锁(Fair):加锁前检查是否有排队等待的线程,优先排队等待的线程,先来先得
非公平锁(Nonfair):加锁时不考虑排队等待问题,直接尝试获取锁,获取不到自动到队尾等待
首先Java中的ReentrantLock 默认的lock()方法采用的是非公平锁。

公平锁的效率较低,但是不会引起线程的饿死
非公平锁的效率较高,但是会引起线程的饿死

可重入锁与不可重入锁
广义上的可重入锁指的是可重复可递归调用的锁,在外层使用锁之后,在内层仍然可以使用,并且不发生死锁(前提得是同一个对象或者class),这样的锁就叫做可重入锁。ReentrantLock和synchronized都是可重入锁。
可重入锁最大作用是避免死锁。
当一个线程执行一个带锁的代码块或方法,同时代码块或方法里也获取同一个锁。为了避免死锁,此时就可以用可重入锁。

不可重入锁
不可重入锁,与可重入锁相反,不可递归调用,递归调用就发生死锁。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值