使用jstack查看线程堆栈信息
jstack:jdk提供的一个工具,可以查看java进程中线程堆栈信息。
位于:jdk1.8.0_121\bin包下
死锁代码
public class DeadLockDemo {private static String A = "A";private static String B = "B";public static void main(String[] args) {new DeadLockDemo().deadLock();}private void deadLock() {Thread t1 = new Thread(() -> {synchronized (A) {try { Thread.currentThread().sleep(2000);} catch (InterruptedException e) {e.printStackTrace();}synchronized (B) {System.out.println("1");}}});Thread t2 = new Thread(() -> {synchronized (B) {synchronized (A) {System.out.println("2");}}});t1.start();t2.start();}}
解释产生原因:
t1拿到锁将资源A锁住,此时时间片到了,线程切换到t2,t2锁住了资源B,此时轮到t1继续执行t1想锁住资源B
由于synchronized是独占型锁,t1只能等t2释放B的资源,但是t2又需要锁住资源A才能执行完代码并释放锁
此时t1等待t2释放资源,t2等待t1释放资源,此时就形成了死锁
具体的死锁相关概念请看我的另一边博客,这里就不详细介绍了
博客地址:http://t.csdnimg.cn/07ORE
如何查询死锁信息
1.首先程序一直未结束,上段代码就可能出现了死锁现象
2.找到上面说的那个工具双击点击后是这个页面
3.找到我们运行的程序,并点击线程
4.此时出现了提示检测到死锁,然后我们点击线程 Dump
5.然后根据信息,我们可以清楚的看到程序发生死锁的原因