首页 > 其他 > 详细

死锁及定位分析

时间:2020-01-08 20:40:09      阅读:77      评论:0      收藏:0      [点我收藏+]

死锁是指两个或两个以上的进程在执行过程中,因争夺资源而造成的一种互相等待的现象,若无外力来干涉那他们都将无法推进下去,如果系统资源充足,进程的资源请求都能得到满足,死锁出现的可能性就很低,否则就会因争夺有限的资源而陷入死锁。

例子:

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);
try {TimeUnit.SECONDS.sleep(2);} catch (InterruptedException e) {e.printStackTrace();}
synchronized (lockB) {
System.out.println(Thread.currentThread().getName()+"\t 自己持有:" +lockB+"\t尝试获得:" +lockA);
}
}
}
}

/**
* 死锁是指两个或两个以上的进程在执行过程中,因争夺资源而造成的一种互相等待的现象,
* 若无外力干涉那它们都将无法推进下去
*
*/
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();
}
}
运行结果见下图,陷入了死循环:

技术分享图片

 

 

怎么定位是否是死锁问题?
第一步:打开idea的终端界面Terminal,输入 jps -l (是小写英文字母l),查看到进程编号是94700

技术分享图片

 

第二步:输入命令:  jstack 94700   ,可以看到,是死锁导致。

技术分享图片

技术分享图片

死锁及定位分析

原文:https://www.cnblogs.com/liuyi13535496566/p/12168284.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!