Java多线程之死锁编码及定位分析

Java多线程之死锁编码及定位分析


目录

  1. 死锁是什么
  2. 代码实现
  3. 死锁解决办法

1. 死锁是什么

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

在这里插入图片描述

2. 代码实现

  1. 代码实现
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);
            //暂停一会儿线程
            try {
                TimeUnit.SECONDS.sleep(1);
            } 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();

    }
}

3. 死锁解决办法


  1. jps命令定位进程号
    在这里插入图片描述

  2. jstack找到死锁查看

命令: jstack 进程号 显示结果

在这里插入图片描述


版权声明:本文为weixin_41910694原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。