如何使用thread dump?你将如何分析Thread dump?

 

 

 

  • 新建状态(New) 

    用new语句创建的线程处于新建状态,此时它和其他Java对象一样,仅仅在堆区中被分配了内存。

  • 就绪状态(Runnable) 

    当一个线程对象创建后,其他线程调用它的start()方法,该线程就进入就绪状态,Java虚拟机会为它创建方法调用栈和程序计数器。处于这个状态的线程位于可运行池中,等待获得CPU的使用权。

  • 运行状态(Running) 

    处于这个状态的线程占用CPU,执行程序代码。只有处于就绪状态的线程才有机会转到运行状态。

  • 阻塞状态(Blocked) 

    阻塞状态是指线程因为某些原因放弃CPU,暂时停止运行。当线程处于阻塞状态时,Java虚拟机不会给线程分配CPU。直到线程重新进入就绪状态,它才有机会转到运行状态。 

    阻塞状态可分为以下3种:

    ① 位于对象等待池中的阻塞状态(Blocked in object’s wait pool):当线程处于运行状态时,如果执行了某个对象的wait()方法,Java虚拟机就会把线程放到这个对象的等待池中,这涉及到“线程通信”的内容。

    ② 位于对象锁池中的阻塞状态(Blocked in object’s lock pool):当线程处于运行状态时,试图获得某个对象的同步锁时,如果该对象的同步锁已经被其他线程占用,Java虚拟机就会把这个线程放到这个对象的锁池中,这涉及到“线程同步”的内容。

    ③ 其他阻塞状态(Otherwise Blocked):当前线程执行了sleep()方法,或者调用了其他线程的join()方法,或者发出了I/O请求时,就会进入这个状态。

  • 死亡状态(Dead)

    当线程退出run()方法时,就进入死亡状态,该线程结束生命周期。

我们运行之前的那个死锁代码SimpleDeadLock.java,然后尝试输出信息(/*这是注释,作者自己加的*/):

/* 时间,jvm信息 */
2017-11-01 17:36:28
Full thread dump Java HotSpot(TM) 64-Bit Server VM (25.144-b01 mixed mode):

/* 线程名称:DestroyJavaVM
编号:#13
优先级:5
系统优先级:0
jvm内部线程id:0x0000000001c88800
对应系统线程id(NativeThread ID):0x1c18
线程状态: wai
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Java Thread dump是Java应用程序运行时的快照,它记录了Java虚拟机中所有线程的状态和调用栈信息。通过分析Thread dump可以帮助我们解决Java应用程序出现的性能问题和死锁等问题。 以下是Java Thread dump分析的步骤: 1. 获取Thread dump 可以使用jstack命令来获取Java应用程序的Thread dump。例如,可以在Linux系统中使用以下命令来获取正在运行的Java进程的Thread dump: ``` jstack <pid> > thread-dump.txt ``` 其中,<pid>是Java应用程序的进程ID。 2. 分析Thread dump Thread dump通常是一个文本文件,可以使用文本编辑器打开并查看。在Thread dump中,每个线程都有自己的ID和状态,例如运行、睡眠等。另外,每个线程还有自己的调用栈信息,它们显示了该线程正在执行的方法以及它们的调用关系。 通过分析Thread dump,我们可以找到可能存在的性能问题和死锁。例如,可以查找正在运行的线程中占用CPU时间最长的线程,并分析其调用栈信息,找出可能存在的性能问题。另外,可以查找睡眠状态的线程,并分析它们的调用栈信息,找出可能存在的死锁问题。 3. 解决问题 根据Thread dump分析结果,我们可以采取相应的措施来解决问题。例如,可以对性能问题进行优化,例如缓存数据、减少I/O操作等。对于死锁问题,可以使用Java提供的synchronized关键字来保证线程同步,或者使用Lock接口提供的锁来实现更灵活的线程同步。 综上所述,Java Thread dump分析是解决Java应用程序性能问题和死锁等问题的重要手段。通过分析Thread dump,我们可以找到问题的根源,并采取相应的措施来解决问题。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值