【校招VIP】Java中死锁现象怎么解决

05月13日 收藏 0 评论 1 java开发

【校招VIP】Java中死锁现象怎么解决

文章申明:转载来源:https://blog.csdn.net/weixin_34786066/article/details/114859531

死锁是这样一种情形:多个线程同时被阻塞,它们中的一个或者全部都在等待某个资源被释放。由于线程被无限期地阻塞,因此程序不可能正常终止。

java 死锁产生的四个必要条件:

1、互斥使用,即当资源被一个线程使用(占有)时,别的线程不能使用

2、不可抢占,资源请求者不能强制从资源占有者手中夺取资源,资源只能由资源占有者主动释放。

3、请求和保持,即当资源请求者在请求其他的资源的同时保持对原有资源的占有。

4、循环等待,即存在一个等待队列:P1占有P2的资源,P2占有P3的资源,P3占有P1的资源。这样就形成了一个等待环路。

当上述四个条件都成立的时候,便形成死锁。当然,死锁的情况下如果打破上述任何一个条件,便可让死锁消失。下面用java代码来模拟一下死锁的产生。

而如果不恰当的使用了锁,且出现同时要锁多个对象时,会出现死锁情况,如下:

package lance.Thread;

import java.util.Date;

/**

* 死锁测试

*

* @author Administrator

*

*/

public class lockTest {

public static String obj1 = "obj1";

public static String obj2 = "obj2";

public static void main(String[] args) {

LockA la = new LockA();

new Thread(la).start();

LockB lb = new LockB();

new Thread(lb).start();

}

}

class LockA implements Runnable {

@Override

public void run() {

try {

System.out.println(new Date().toString() + "LockA开始执行");

while (true) {

synchronized (lockTest.obj1) {

System.out.println(new Date().toString() + " LockA 锁住 obj1");

Thread.sleep(2000);

synchronized (lockTest.obj2) {

System.out.println(new Date().toString() + " LockA 锁住 obj2");

Thread.sleep(60 * 1000); // 为测试,占用了就不放

}

}

}

} catch (Exception e) {

e.printStackTrace();

}

}

}

class LockB implements Runnable {

@Override

public void run() {

try {

System.out.println(new Date().toString() + "LockB开始执行");

while (true) {

synchronized (lockTest.obj2) {

System.out.println(new Date().toString() + " LockB 锁住 obj2");

Thread.sleep(2000);

synchronized (lockTest.obj1) {

System.out.println(new Date().toString() + " LockB 锁住 obj1");

Thread.sleep(60 * 1000); // 为测试,占用了就不放

}

}

}

} catch (Exception e) {

e.printStackTrace();

}

}

}

此时死锁产生。

死锁解决办法:

1.当几个线程都要访问共享资源A、B、C时,保证使每个线程都按照同样的顺序去访问它们,比如都先访问A,在访问B和C。
2.尽可能只一个对象,这样永远不会出现死锁情况

C 1条回复 评论
杨微粒

不错,慢慢看

发表于 2022-08-28 21:00:00
0 0