1.什么是死锁
死锁是指两个或者两个以上的进程在执行过程中,因争夺资源而造成的一种相互等待的现象,若无外力干涉将无法推进下去,如果系统资源充足,进程资源都能够满足,死锁出现的可能性就很低,否则就会因争夺资源而陷入死死锁
package com.thread;
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+"尝试获取:"+lockB);
try {
TimeUnit.SECONDS.sleep(2);
} catch (Exception e) {
e.printStackTrace();
}
synchronized (lockB){
System.out.println(Thread.currentThread().getName()+"\t 自己持有:"+lockB+"尝试获取:"+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();
}
}
输出结果:
AAA 自己持有:lockA尝试获取:lockB
BBB 自己持有:lockB尝试获取:lockA
2.证明为什么出现了死锁?
Linux ps -ef | grep XXX ls -l
Windows 下java运行程序也有类似于ps 查看进行的命令但是目前我们需要查看的是 java
jps = java ps jps -l
找到出现问题的进程号 8804