package com.atguigu.thread.deadlock;
public class DeadLockDemo
{
    public static void main(String[] args)
    {
        String lockA = "lockA";
        String lockB = "lockB";
        new Thread(new HoldLockThread(lockA, lockB), "AAA").start();
        new Thread(new HoldLockThread(lockB, lockA), "BBB").start();
    }
}
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
            {
                Thread.sleep(2000L);
            }
            catch (InterruptedException e)
            {
                e.printStackTrace();
            }
            synchronized (lockB)
            {
                System.out.println(
                    Thread.currentThread().getName() + "\t自己持有:" + lockB + "\t尝试获取" + lockA);
            }
        }
    }
}
运行之后:
    
   
死锁的排查:
在对应文件的目录下打开cmd窗口,输入jps -l 查看进程号
再执行jstack 进程号:来分析原因
    
   
 
版权声明:本文为weixin_40264444原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。