如何定位&避免死锁
https://www.bilibili.com/video/BV1d84y1R71V/?spm_id_from=333.999.0.0&vd_source=a3fefff79a3be320da3db60b271f05c9
1、死锁伪代码
2、如何定位:
jps 找到进程id
jstack pid 去查看栈情况
会显示 find a deadlock
3、如何解决
破坏死锁的四个条件,但是破坏掉这些条件需要抑制系统的性能,而且这四个条件都满足了也不一定产生死锁。我们只需要去有一定几率的避免死锁即可。银行家算法就是去避免这个事情。
(1)破坏互斥:
使用乐观锁,原子操作、CAS、ThreadLocal
(2)破坏占有且等待条件:
直接一次申请所有资源,增加一个锁管理场
(3)破怀不可抢占:
申请不到资源主动释放锁
(4)破坏循环等待:
对锁对象按照id进行排序,只能按照顺序进行获取锁