首先说一下什么是死锁:死锁是指两个或两个以上的进程在执行过程中,由于竞争资源或者由于彼此通信而造成的一种阻塞的现象,若无外力作用,它们都将无法推进下去。
如下图所示:
是不是很好理解:
眼睛:懂了 脑袋:明白了 手:别自欺欺人了
俗话说光说不练假把式、光练不说傻把式、今天我们不仅要明白理论,还要手写一个死锁的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();
}
}
这个时候我们看开发工具状态和控制台的信息如下:
是吧,死锁了,但是正常情况是你的代码打到了生产环境,你要进行排除这个问题,那应该怎么排除呢,两个命令-->jps、jstack
下面演示排查代码死锁问题:
继续往下看啊铁子们,接续看截图:
看到了吧铁子们,生产遇见问题就可以这样进展,导致原因很明显了,哪一行代码都指出来了,私底下开发小伙伴就可以偷偷赶紧把程序改下吧
ps:养成习惯不白嫖、点赞收藏评论好好好
到此就结束了,你是不是对线程池的提交方式有了新的理解了呢,感兴趣的可以扫码关注博主的公众号,会不定期推送优质技术文章的哦