jstack分析多线程死锁,来吧_jstack deadlock(1)

给大家的福利

零基础入门

对于从来没有接触过网络安全的同学,我们帮你准备了详细的学习成长路线图。可以说是最科学最系统的学习路线,大家跟着这个大的方向学习准没问题。

同时每个成长路线对应的板块都有配套的视频提供:

在这里插入图片描述

因篇幅有限,仅展示部分资料

网络安全面试题

绿盟护网行动

还有大家最喜欢的黑客技术

网络安全源码合集+工具包

所有资料共282G,朋友们如果有需要全套《网络安全入门+黑客进阶学习资源包》,可以扫描下方二维码领取(如遇扫码问题,可以在评论区留言领取哦)~

需要体系化学习资料的朋友,可以加我V获取:vip204888 (备注网络安全)

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化资料的朋友,可以点击这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

public void run() {
      invoke();
    }
}

class B extends T implements Runnable {
    T next;
    public synchronized void invoke() {
        System.out.println(“当前线程:” + Thread.currentThread().getName()
                + " | 进入了" + this.getClass().getSimpleName() + " 获取到资源 | 准备调用:"
                + next.getClass().getSimpleName());
        try {
            Thread.sleep(1000);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        next.invoke();
    }

@Override
    public void run() {
        invoke();
    }
}

class T {
  public synchronized void invoke(){ }
}


上面的代码也很简单,就是A对象`持有`B对象的`引用`,B对象`持有`A对象的`引用`。


在线程a进入到`invoke`方法时`锁住`了A对象,线程b也进入到invoke方法锁住了B对象。


线程a再`调用`B对象的`invoke`方法去试图锁住B对象时,发现B对象已经被锁住了,需要等待,同理b线程也是如此。


就导致了两个线程相互等待对方释放锁。有点绕,如果不明白,好好品下。


咱们运行下上面的代码,看下结果:



当前线程:aThread | 进入了A 获取到资源 | 准备调用:B
当前线程:bThread | 进入了B 获取到资源 | 准备调用:A


### 2、查找进程日志


我们使用jps查找进程,再用jstack dump线程日志信息


![图片](https://img-blog.csdnimg.cn/img_convert/95e8222bb4fb920a1db130facefdac56.png)


  
 dump的时候忘记加磁盘标识,结果dump的文件到C:\Users\Administrator这个目录里面去了


### 3、分析


下面我们看看日志里面是怎么记录的,首先,我们全文搜索【deadlock】关键字,如下图:  
![](https://img-blog.csdnimg.cn/b65448ab1e9f466ab9ae3797a9999a9a.gif)上图展示了bThread和aThread发生了死锁,具体是哪块的代码还不清楚,咱们根据A对象0x000000078bb84c68继续往下搜索


![图片](https://img-blog.csdnimg.cn/img_convert/4b1cf5c157288730b078a53dddf5e75f.png)


  
 现在咱们就很清楚死锁的代码所在了,剩下的就是优化代码了。


### 4、总结


一般来说,线程的日志是非常大,不可能一眼就能看出问题的所在,现在我们重点来说排查的思路:


首先就要找关键字,比如:


* **deadlock**:表示有死锁。
* **Waiting on condition**:等待某个资源或条件发生来唤醒自己。
* **Blocked**:阻塞。
* **Waiting on monitor entry**:在等待获取锁。


找到这些关键字,再找到具体的线程进行分析,最后根据线程死锁的执行的方法,去查看代码。


**​  文末福利  
  可以加小新老师vx免费获取【Java高清路线图】和【全套学习视频和配套资料】**  


### 一、网安学习成长路线图


网安所有方向的技术点做的整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照上面的知识点去找对应的学习资源,保证自己学得较为全面。  
 ![在这里插入图片描述](https://img-blog.csdnimg.cn/aa7be04dc8684d7ea43acc0151aebbf1.png)


### 二、网安视频合集


观看零基础学习视频,看视频学习是最快捷也是最有效果的方式,跟着视频中老师的思路,从基础到深入,还是很容易入门的。  
 ![在这里插入图片描述](https://img-blog.csdnimg.cn/f0aeee2eec7a48f4ad7d083932cb095d.png)


### 三、精品网安学习书籍

当我学到一定基础,有自己的理解能力的时候,会去阅读一些前辈整理的书籍或者手写的笔记资料,这些笔记详细记载了他们对一些技术点的理解,这些理解是比较独到,可以学到不一样的思路。  
 ![在这里插入图片描述](https://img-blog.csdnimg.cn/078ea1d4cda342f496f9276a4cda5fcf.png)


### 四、网络安全源码合集+工具包

光学理论是没用的,要学会跟着一起敲,要动手实操,才能将自己的所学运用到实际当中去,这时候可以搞点实战案例来学习。  
 **需要体系化学习资料的朋友,可以加我V获取:vip204888 (备注网络安全)**

![在这里插入图片描述](https://img-blog.csdnimg.cn/e54c0bac8f3049928b488dc1e5080fc5.png)


### 五、网络安全面试题


最后就是大家最关心的网络安全面试题板块  
 ![在这里插入图片描述](https://img-blog.csdnimg.cn/15c1192cad414044b4dd41f3df44433d.png)![在这里插入图片描述](https://img-blog.csdnimg.cn/b07abbfab1fd4edc800d7db3eabb956e.png)  



**网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。**

**[需要这份系统化资料的朋友,可以点击这里获取](https://bbs.csdn.net/topics/618540462)**

**一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**

  • 18
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值