什么是死锁
死锁是指两个或以上的进程在执行过程中,因争夺资源而造成的一种互相等待的现象。若无外力干涉将无法推进,如果系统资源充足,进程的资源请求都能够得到满足,死锁出现的可能性就很低,否则就会因争夺有限的资源而陷入死锁。
产生死锁的主要原因
- 系统资源不足
- 进程运行推进的顺序不合适
- 资源分配不当
产生死锁的必要条件
- 互斥访问
- 请求并保持
- 循环等待
- 不可剥夺
代码实现
package com.company;
import java.util.concurrent.TimeUnit;
class HoldLock implements Runnable
{
private String lockA;
private String lockB;
public HoldLock(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 HoldLock(lockA,lockB),"AAA").start();
new Thread(new HoldLock(lockB,lockA),"BBB").start();
}
}
解决死锁
windows下的Java运行程序,也有类似于ps 的查看进程的命令,但是目前需要查看的只是java
linux | windows下的Java运行程序 |
---|---|
ps -ef | grep xxxx|jps |
ls -l | jps -l |