死锁及定位分析

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

例子:

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   ,可以看到,是死锁导致。

猜你喜欢

转载自www.cnblogs.com/liuyi13535496566/p/12168284.html