1.3w字,一文详解死锁!(7)

简介: 1.3w字,一文详解死锁!(7)

然后点击“线程”,勾中“死锁检测”就可以发现死锁和死锁的详情信息,如下图所示:


image.png


4.死锁解决方案


4.1 死锁解决方案分析


接下来我们来分析一下,产生死锁的 4 个条件,哪些是可以破坏的?哪些是不能被破坏的?


  • 互斥条件:系统特性,不能被破坏。


  • 请求和保持条件:可以被破坏。


  • 不可剥夺条件:系统特性,不能被破坏。


  • 环路等待条件:可以被破坏。


通过上述分析,我们可以得出结论,我们只能通过破坏请求和保持条件或者是环路等待条件,从而来解决死锁的问题,那上线,我们就先从破坏“环路等待条件”开始来解决死锁问题。


4.2 解决方案1:顺序锁


所谓的顺序锁指的是通过有顺序的获取锁,从而避免产生环路等待条件,从而解决死锁问题的。


当我们没有使用顺序锁时,程序的执行可能是这样的:


image.png


线程 1 先获取了锁 A,再获取锁 B,线程 2 与 线程 1 同时执行,线程 2 先获取锁 B,再获取锁 A,这样双方都先占用了各自的资源(锁 A 和锁 B)之后,再尝试获取对方的锁,从而造成了环路等待问题,最后造成了死锁的问题。


此时我们只需要将线程 1 和线程 2 获取锁的顺序进行统一,也就是线程 1 和线程 2 同时执行之后,都先获取锁 A,再获取锁 B,执行流程如下图所示:


image.png


因为只有一个线程能成功获取到锁 A,没有获取到锁 A 的线程就会等待先获取锁 A,此时得到锁 A 的线程继续获取锁 B,因为没有线程争抢和拥有锁 B,那么得到锁 A 的线程就会顺利的拥有锁 B,之后执行相应的代码再将锁资源全部释放,然后另一个等待获取锁 A 的线程就可以成功获取到锁资源,执行后续的代码,这样就不会出现死锁的问题了。

相关文章
|
算法 安全 Java
Java多线程与并发框(完结篇)——再看不懂我找不到女朋友
Java多线程与并发框(完结篇)——再看不懂我找不到女朋友
62 0
Java多线程与并发框(完结篇)——再看不懂我找不到女朋友
|
存储 安全 Java
Java多线程基础——两万字详解
进程简单来说就是正在运行的程序,是可以通过双击执行的.exe文件,打开我们电脑的任务管理器,可以看到我们的电脑正在执行的进程,目前我们的电脑都是多进程模式。
119 0
Java多线程基础——两万字详解
|
存储 缓存 安全
2w字 + 40张图带你参透并发编程!(一)
在计算机最早期的时候,没有操作系统,执行程序只需要一种方式,那就是从头到尾依次执行。任何资源都会为这个程序服务,在计算机使用某些资源时,其他资源就会空闲,就会存在 浪费资源 的情况。
2w字 + 40张图带你参透并发编程!(一)
|
监控 Java
1.3w字,一文详解死锁!(4)
1.3w字,一文详解死锁!(4)
88 0
1.3w字,一文详解死锁!(4)
1.3w字,一文详解死锁!(13)
1.3w字,一文详解死锁!(13)
87 0
1.3w字,一文详解死锁!(13)
1.3w字,一文详解死锁!(1)
1.3w字,一文详解死锁!(1)
84 0
1.3w字,一文详解死锁!(1)
|
Java
1.3w字,一文详解死锁!(14)
1.3w字,一文详解死锁!(14)
110 0
1.3w字,一文详解死锁!(14)
|
运维 监控 Oracle
1.3w字,一文详解死锁!(6)
1.3w字,一文详解死锁!(6)
111 0
1.3w字,一文详解死锁!(6)
1.3w字,一文详解死锁!(8)
1.3w字,一文详解死锁!(8)
87 0
1.3w字,一文详解死锁!(8)
1.3w字,一文详解死锁!(11)
1.3w字,一文详解死锁!(11)
62 0
1.3w字,一文详解死锁!(11)