(三)JUC - 多线程锁

本文介绍了Java中的几种锁机制,包括悲观锁和乐观锁的概念及应用场景,如synchronized和CAS算法。接着讨论了公平锁与非公平锁的区别,并解释了为何默认使用非公平锁。此外,还阐述了可重入锁(递归锁)的特性,以及在Java中如何实现。最后,文章提到了死锁的定义、产生原因,并给出了排查死锁的方法。

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

目录

1. 悲观锁 / 乐观锁

2. 锁运行后的8种情况:

3. 公平锁 / 非公平锁

4. 可重入锁(递归锁)

5. 死锁


1. 悲观锁 / 乐观锁

悲观锁:synchronized、lock

适合场景:写操作多  ---狼性锁

乐观锁:CAS算法,java原子类中的递增操作就通过CAS自旋实现的。

适合场景:读操作多  ---佛系锁

2. 锁运行后的8种情况:


synchronized

monitorenter指令

……

monitorexit指令

重要面试题:为什么任何一个对象都可以成为一个synchronized锁?

HotSpot  ObjectMonitor.java

3. 公平锁 / 非公平锁

公平锁 fair

非公平锁 unfair

卖票Demo:3个售票员卖50张票

Q:为什么会有公平锁/非公平锁的设计?为什么默认非公平?

4. 可重入锁递归锁)

隐式锁 synchronized

显式锁 Lock

lock()和unlock() 要一一配对

5. 死锁

1)是什么

2)产生原因

3)如何排查死锁?

纯命令、图形化

>jps -l

pid

>jstack [进程编号]

Found 1 deadlock

cmd 输入 jconsole

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值