• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

Java项目有中多个线程如何查找死锁

java 搞代码 4年前 (2022-01-05) 17次浏览 已收录 0个评论
文章目录[隐藏]

这篇文章主要介绍了Java项目有中多个线程如何查找死锁,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

当项目有中多个线程,如何查找死锁?

最近,在IDEA上进行多线程编程中老是在给线程加锁的时候,总是会遇到死锁问题,而当程序出现死锁问题时,编译器不能精确的显示错误的精确位置。当项目代码很多的时候, 往往会给自己添加不必要的麻烦,今天,我就分享分享几个解决方法。

1.编译环境

IDEA 2020 ,windows10, jdk8及以上版本

一、死锁是什么?

死锁指A线程想使用资源但是被B线程占用了,B线程线程想使用资源被A线程占用了,导致程序无法继续下去了。

1.1 死锁的例子;

 public class Deadlock { public static void main(String[] args) { Object lock1 = new Object(); Object lock2 = new Object(); Thread thread1 = new Thread(new Runnable() { @Override public void run() { synchronized (lock1){ System.out.println("线程一得到了lock1"); try{ Thread.sleep(1000); } catch (InterruptedException e) { e.printStackTrace(); } System.out.println("线程一获取lock2"); synchronized (lock2){ System.out.println("线程一得到了lock2"); } } } }); thread1.start(); Thread thread2 = new Thread(new Runnable() { @Override public void run() { synchronized (lock2){ System.out.println("线程二得到了lock2"); try{ //让线程2,获取锁1 Thread.sleep(1000); } catch (InterruptedException e) { e.printStackTrace(); } System.out.println("线程二获取lock1"); //尝试获取lock1 synchronized (lock1){ System.out.println("线程二得到了lock1"); } } } }); thread2.start(); } }

1.2 死锁的例子;

形成死锁的条件:
1.互斥条件:(当一个资源被一个线程拥有,当被一个线程拥有后就不能被其他线程所持有)
2.请求拥有条件(一个线程所持有一个资源后又试图请求另来源gaodai$ma#com搞$$代**码网一个资源)可修改
3.不可剥夺性:(一个资源被一个线程拥有之后,如果这个线程不释放此资源,那么其他线程不能强制获得此资源)
4.环路等待条件(多个线程在获取资源时形成一个环形链)可修改

二、使用jdk内置工具检测死锁

方法一. jconsole.exe

进入你的jdk安装路径中,打开jdk/bin/jconsole.exe
使用步骤如下:

检测结果:

方法二. jvisualvm.exe

进入你的jdk安装路径中,打开jdk/bin/jvisualvm.exe
优点:比较细,比较全面
缺点:加载有点慢!
使用步骤如下:

可以在里面看到是该项目代码的第39行出现了死锁。

方法三. jmc.exe

进入你的jdk安装路径中,打开jdk/bin/jmc.exe
优点:可以对所以死锁进行判断
缺点:没有给出解决方法
使用步骤如下:

三、死锁解决方法

通过死锁的形成条件来解决死锁问题,从根源上消除死锁。
1.请求拥有条件(一个线程所持有一个资源后又试图请求另一个资源)可修改
2.环路等待条件(多个线程在获取资源时形成一个环形链)可修改

举例修改: 方法:(修改环路等待条件)
//让线程二和线程一竞争同一个锁,修改为并行,这样避免出现环路

 public class Deadlock { public static void main(String[] args) { Object lock1 = new Object(); Object lock2 = new Object(); Thread thread1 = new Thread(new Runnable() { @Override public void run() { synchronized (lock1){ System.out.println("线程一得到了lock1"); try{ Thread.sleep(1000); } catch (InterruptedException e) { e.printStackTrace(); } System.out.println("线程一获取lock2"); synchronized (lock2){ System.out.println("线程一得到了lock2"); } } } }); thread1.start(); Thread thread2 = new Thread(new Runnable() { @Override public void run() { synchronized (lock1){   //让线程二和线程一竞争同一个锁,修改为并行,这样避免出现环路 System.out.println("线程二得到了lock1"); try{ //让线程2,获取锁1 Thread.sleep(1000); } catch (InterruptedException e) { e.printStackTrace(); } System.out.println("线程二获取lock1"); //尝试获取lock1 synchronized (lock2){ System.out.println("线程二得到了lock2"); } } } }); thread2.start(); } }

四、总结

以上就是Java项目有中多个线程如何查找死锁的详细内容,更多请关注gaodaima搞代码网其它相关文章!


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:Java项目有中多个线程如何查找死锁

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址