大部分情况下并不会产生死锁,只有在极端情况下才会产生死锁的问题,
死锁产生的原因主要有以下四点:
1.互斥作用:一把锁只能锁住一个线程(这是锁的基本特性,除非修改源码,不太现实)
2.不可抢占:线程1抢到了锁,线程2就不能用这个锁了,要等待线程1释放锁(这个也是和1差不多)
3.请求与保持:在多线程的情况下,线程1拿到了锁1之后,在保持锁1不释放的情况下,还请求拿到锁2(这个取决于代码的具体实现,)
4.循环等待:线程1要想拿到锁需要线程2释放锁,线程2要拿到锁需要线程3释放锁,线程3要拿到锁需要线程1释放锁.
具体代码实现死锁~~
线程1在获取到锁1 的前提下还想获取锁2
线程2在获取锁2的前提下还想获取锁1
循环等待的情况下就导致了死锁的情况发生了
而解决办法发就是将两个线程同时去抢锁1,线程1抢到了就进行后续线程1对锁2的抢夺,没抢到的线程2就阻塞等待,等到 线程1释放了锁1线程2再去抢锁1,此时的线程1已经到了抢夺锁2的逻辑,线程2还在锁1的获取中,两个线程就此错开也就不会形成死锁的情况了
还有一个解决死锁问题的方案:银行家算法(将所有的资源统一进行统筹分配)就避免了死锁的情况.但比较难,这里不做讨论