死锁的定义是:两个或两个以上的线程或进程在执行过程中,由于竞争资源或者由于彼此通信而造成的一种阻塞的现象。
用白话讲就是:现在有线程1和线程2。线程1执行过程中,先锁定了对象a,然后需要再锁定b才能继续执行代码;而线程2正巧相反,先锁定了b,需要再锁定a才能继续执行代码。这时,两个线程都等着对方解锁,才能继续执行,于是两个线程就进入等待状态,最终不会有线程执行。这就变成了死锁。
死锁是在多线程编程中常常遇到的问题,现在用java编写一个简单的死锁程序。
程序在main()方法中启动2个线程,“线程-1”和“线程-2”。 线程-1 先拿到 lock1,再寻求拿到 lock2;线程-2 先拿到loc2,再需求拿到lock1,于是变成循环等待,造成死锁。
1、死锁程序如下:
/**
* @author lwy
* @create 2022-03-14 9:32
*/
public class deadLockTest {
public static void main(String[] args) {
Object lock1 = new Object();
Object lock2 = new Object();
new Thread(() -> {
String name = Thread.currentThread().getName();
synchronized (lock1) {
System.out.println(name + "获得锁1,再去获取锁2");
try {
Thread.sleep(100);
} catch (Exception e) {
e.printStackTrace();
}
synchronized (lock2) {
System.out.println(name + "获得锁2");
System.out.println(name + ":Hello!");
}
}
}, "线程--1").start();
new Thread(() -> {
String name = Thread.currentThread().getName();
synchronized (lock2) {
System.out.println(name + "获得锁2,再去获取锁1");
try {
Thread.sleep(100);
} catch (Exception e) {
e.printStackTrace();
}
synchronized (lock1) {
System.out.println(name + "获得锁1");
System.out.println(name + ":Hello!");
}
}
}, "线程--2").start();
}
}
2、运行结果为:
3、然后在终端输入:jps,查看该程序的进程号:
4、在终端输入:jstack -F 25204查看结果
5、或者在终端输入:jconsole,会弹出Java自带的监视和管理控制台
6、接着点击“线程”
7、再点击“检测死锁”
8、点击“线程