死锁是指两个或两个以上的进程在执行过程中,因争夺资源而造成的一种互相等待的现象,若无外力干涉那它们都将无法推进下去,如果系统资源充足,进程的资源请求都能够碍到满足,死锁出现的可能性就很低,否则就会因争夺有限的资源而陷入死锁。
产生死锁的原因:
- 系统资源不足
- 进程运行推进的顺序不合适
- 资源分配不当
发生死锁的四个条件:
- 互条件,线程使用的资源至少有一个不能共享的。
- 至少有一个线程必须持有一个资源且正在等待获取一个当前被别的线程持有的资源。
- 资源不能被抢占。
- 循环等待.
如何解决死锁问题:
破坏发生死锁的四个条件其中之一即可。
查看是否死锁工具:
windows idea
jps -l 命令定位进程号
jstack 进程号 找到死锁查看
死锁案例
class LockResouse implements Runnable{
private String lockA;
private String lockB;
public LockResouse(String lockA, String lockB) {
this.lockA = lockA;
this.lockB = lockB;
}
@Override
public void run() {
synchronized (lockA){
System.out.println(Thread.currentThread().getName()+"拿到"+lockA+" 尝试获取"+lockB);
synchronized (lockB){
System.out.println(Thread.currentThread().getName()+"拿到"+lockB+"尝试获取"+lockA);
}
}
}
}
public class DealLock {
public static void main(String[] args) {
String lockA="lockA";
String lockB="lockB";
new Thread(new LockResouse(lockA,lockB),"AAA").start();
new Thread(new LockResouse(lockB,lockA),"BBB").start();
}
}
AAA拿到lockA 尝试获取lockB
BBB拿到lockB 尝试获取lockA
Found one Java-level deadlock:
=============================
"BBB":
waiting to lock monitor 0x000000001d02f758 (object 0x000000076c4354f8, a java.lang.String),
which is held by "AAA"
"AAA":
waiting to lock monitor 0x000000001d0321f8 (object 0x000000076c435530, a java.lang.String),
which is held by "BBB"
Java stack information for the threads listed above:
===================================================
"BBB":
at com.ruoyi.web.webmagic.model.demo.LockResouse.run(DealLock.java:19)
- waiting to lock <0x000000076c4354f8> (a java.lang.String)
- locked <0x000000076c435530> (a java.lang.String)
at java.lang.Thread.run(Thread.java:745)
"AAA":
at com.ruoyi.web.webmagic.model.demo.LockResouse.run(DealLock.java:19)
- waiting to lock <0x000000076c435530> (a java.lang.String)
- locked <0x000000076c4354f8> (a java.lang.String)
at java.lang.Thread.run(Thread.java:745)
Found 1 deadlock.