前言
2022 10/11 20:27
路漫漫其修远兮,吾将上下而求索
本文是根据尚硅谷学习所做笔记
仅供学习交流使用,转载注明出处
推荐
10.死锁编码及定位分析
说明
本文目录前是相关视频的名字和具体视频中思维导图的名字
题目
10.死锁编码及定位分析
55 死锁编码及定位分析
是什么
死锁是指两个或两个以上的进程在执行过程中,因争夺资源而造成的一种互相等待的现象,往无外力干涉那它们都将无法推进下去,如果系统资源充足,进程的资源请求都能够得到满足,死锁出现的可能性就很低,否则就会因争夺有限的资源而陷入死锁。
产生死锁主要原因
- 系统资源不足
- 进程运行推进的顺序不合适
- 资源分配不当
代码
package deadlock10; import java.util.concurrent.TimeUnit; class HoldLockThread implements Runnable{ private String lockA; private String lockB; public HoldLockThread(String lockA, String lockB) { this.lockA = lockA; this.lockB = lockB; } @Override public void run() { synchronized (lockA){ System.out.println(Thread.currentThread().getName()+"\t 自己持有"+lockA+"\t 尝试获得:"+lockB); //tsleep try{ TimeUnit.SECONDS.sleep(2); }catch (InterruptedException e){ e.printStackTrace(); } synchronized (lockB){ System.out.println(Thread.currentThread().getName()+"\t 自己持有"+lockB+"\t 尝试获得:"+lockA); } } } } /** * @author CSDN@日星月云 * @date 2022/10/11 20:35 * * 死锁是指两个或两个以上的进程在执行过程中, * 因争夺资源而造成的一种互相等待的现象, * 往无外力干涉那它们都将无法推进下去, */ public class DeadLockDemo { public static void main(String[] args) { String lockA="lockA"; String lockB="lockB"; new Thread(new HoldLockThread(lockA,lockB),"ThreadAAA").start(); new Thread(new HoldLockThread(lockB,lockA),"ThreadBBB").start(); } }
ThreadAAA 自己持有lockA 尝试获得:lockB ThreadBBB 自己持有lockB 尝试获得:lockA
解决
jsp命令定位进程号
jstack找到死锁查看
E:\IdeaProjects\JavaMS\second>jps -l 16368 org.jetbrains.jps.cmdline.Launcher 18932 deadlock10.DeadLockDemo 16168 16652 sun.tools.jps.Jps E:\IdeaProjects\JavaMS\second>jstack 18932 ... Java stack information for the threads listed above: =================================================== "ThreadBBB": at deadlock10.HoldLockThread.run(DeadLockDemo.java:23) - waiting to lock <0x00000000d8e0f298> (a java.lang.String) - locked <0x00000000d8e0f2d0> (a java.lang.String) at java.lang.Thread.run(Thread.java:745) "ThreadAAA": at deadlock10.HoldLockThread.run(DeadLockDemo.java:23) - waiting to lock <0x00000000d8e0f2d0> (a java.lang.String) - locked <0x00000000d8e0f298> (a java.lang.String) at java.lang.Thread.run(Thread.java:745) Found 1 deadlock.
最后
2022 10/11 20:55
p55
Markdown 2351 字数 154 行数
HTML 2096 字数 89 段落