Java多线程死锁产生的原因及解决方法

  1. 死锁的定义

    多线程以及多进程改善了系统资源的利用率并提高了系统 的处理能力。然而,并发执行也带来了新的问题——死锁。所谓死锁是指多个线程因竞争资源而造成的一种僵局(互相等待),若无外力作用,这些进程都将无法向前推进。

  2. 死锁产生的原因

    1. 系统资源的竞争
    2. 进程推进顺序非法进程在运行过程中,请求和释放资源的顺序不当,也同样会导致死锁。
    3. 信号量使用不当也会造成死锁。
  3. 死锁产生的必要条件,产生死锁必须同时满足以下四个条件,只要其中任一条件不成立,死锁就不会发生

    1. 互斥条件:进程要求对所分配的资源进行排他性控制,即在一段时间内一个资源仅为一个进程所占有。此时若有其他进程请求该资源,则请求进程只能等待。
    2. 不剥夺条件:进程所获得的资源在未使用完毕之前,不能被其他进程强行夺走,即只能由获得该资源的进程自己来释放
    3. 请求和保持条件:进程已经保持了至少一个资源,但又提出了新的资源请求,而该资源已被其他进程占有,此时请求进程被阻塞,对自己已获得的资源保持不放。
    4. 循环等待条件:存在一种进程资源的循环等待链,链中每一个进程已获得的资源同时被链中下一个进程所请求。
  4. 如何避免死锁? 在有些情况下死锁是可以避免的。三种用于避免死锁的技术:

    1. 加锁顺序(线程按顺序加锁)
    2. 加锁时限(线程尝试获取锁的时候加上时间,超过时间则放弃对该锁的请求,并释放自己占有的锁)
    3. 死锁检测

你可能感兴趣的:(Java基础)