1 死锁是什么
死锁是指两个或两个以上的进程在执行过程中,由于竞争资源或者由于彼此通信而造成的一种阻塞的现象,若无外力作用,它们都将无法推进下去。此时称系统处于死锁状态或系统产生了死锁,这些永远在互相等待的进程称为死锁进程
2 死锁演示
public class SiSuoTest {
public static void main(String[] args) {
Object o1 = new Object();
Object o2 = new Object();
new Thread(()->{
synchronized (o1) {
System.out.println("aaaaa");
try { TimeUnit.SECONDS.sleep(1); } catch (InterruptedException e) { e.printStackTrace(); }
synchronized (o2) {
System.out.println("bbbbb");
}
}
}).start();
new Thread(()->{
synchronized (o2) {
System.out.println("ccccccc");
try { TimeUnit.SECONDS.sleep(1); } catch (InterruptedException e) { e.printStackTrace(); }
synchronized (o1) {
System.out.println("dddddddd");
}
}
}).start();
}
}
执行,两个线程都阻塞了
aaaaa
ccccccc
3 死锁产生的四个必要条件
1)互斥条件:共享资源任一时刻只能被一个线程占有
2)请求和保持条件:一个线程因为资源请求阻塞时,对已占有的资源保持不放
3)不剥夺条件:线程已占有的资源无法被其它线程剥夺,只能自己释放
4)循环等待条件:线程之间形成了一个循环等待资源关系
4 解决死锁
破坏上面任一条件即可