首先说一下什么是死锁:死锁是指两个或两个以上的进程在执行过程中,由于竞争资源或者由于彼此通信而造成的一种阻塞的现象,若无外力作用,它们都将无法推进下去。

如下图所示:

java手写一个死锁并排查故障_java技巧

是不是很好理解:

眼睛:懂了     脑袋:明白了    手:别自欺欺人了

俗话说光说不练假把式、光练不说傻把式、今天我们不仅要明白理论,还要手写一个死锁的demo

铁子们咱们也不多说废话了,我就直接上代码了,代码如下:

package com.example.demo.controller;

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(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),"AAA").start();
        new Thread(new HoldLockThread(lockB,lockA),"BBB").start();
    }
}

这个时候我们看开发工具状态和控制台的信息如下:

java手写一个死锁并排查故障_java技巧_02

是吧,死锁了,但是正常情况是你的代码打到了生产环境,你要进行排除这个问题,那应该怎么排除呢,两个命令-->jps、jstack

下面演示排查代码死锁问题:

java手写一个死锁并排查故障_java_03

 继续往下看啊铁子们,接续看截图:

java手写一个死锁并排查故障_java_04

 

看到了吧铁子们,生产遇见问题就可以这样进展,导致原因很明显了,哪一行代码都指出来了,私底下开发小伙伴就可以偷偷赶紧把程序改下吧