java分析dump文件_分析java dump文件

"DestroyJavaVM" prio=6 tid=0x00316800 nid=0x448 waiting on condition [0x00000000

..0x00a0fd4c]

java.lang.Thread.State: RUNNABLE

"Thread-1" prio=6 tid=0x02f85000 nid=0xd18 waiting for monitor entry [0x0319f000

..0x0319fd14]

java.lang.Thread.State: BLOCKED (on object monitor)

at xunlei.kkk.f2(TestLock.java:20)

- waiting to lock <0x22ad0160> (a java.lang.Object)//在“入口区”等待获取<0x22ad0160>

- locked <0x22ad0158> (a java.lang.Object)//获得了监视器<0x22ad0158>

at xunlei.TestLock$2.run(TestLock.java:42)

"Thread-0" prio=6 tid=0x02bff400 nid=0xd40 waiting for monitor entry [0x02f4f000

..0x02f4fd94]

java.lang.Thread.State: BLOCKED (on object monitor)

at xunlei.kkk.f1(TestLock.java:9)

- waiting to lock <0x22ad0158> (a java.lang.Object) 在“入口区”等待获取<0x22ad0158>

- locked <0x22ad0160> (a java.lang.Object) //获得了监视器<0x22ad0160>

at xunlei.TestLock$1.run(TestLock.java:35)

"A2" prio=6 tid=0x02c01400 nid=0xb0c in Object.wait() [0x02fef000..0x02fefa94]

java.lang.Thread.State: WAITING (on object monitor)

at java.lang.Object.wait(Native Method)

- waiting on <0x22a15d48> (a java.lang.Object)//在“等待区”等待获取<0x22a15d48>

at java.lang.Object.wait(Object.java:485)

at xunlei.OutputName.run(Test.java:58)

- locked <0x22a15d48> (a java.lang.Object)

"A1" prio=6 tid=0x02c00000 nid=0xf8 in Object.wait() [0x02f9f000..0x02f9fb14]

java.lang.Thread.State: WAITING (on object monitor)

at java.lang.Object.wait(Native Method)

- waiting on <0x22a15d48> (a java.lang.Object)

at java.lang.Object.wait(Object.java:485)

at xunlei.OutputName.run(Test.java:58)

- locked <0x22a15d48> (a java.lang.Object)

"A0" prio=6 tid=0x02c17800 nid=0xe68 in Object.wait() [0x02f4f000..0x02f4fb94]

java.lang.Thread.State: WAITING (on object monitor)

at java.lang.Object.wait(Native Method)

- waiting on <0x22a15d48> (a java.lang.Object)

at java.lang.Object.wait(Object.java:485)

at xunlei.OutputName.run(Test.java:58)

- locked <0x22a15d48> (a java.lang.Object)

在windows的cmd.exe中运行的java程序,按下ctrl+break,则会弹出此时程序的堆栈,上面显示了线程的几种状态

一、- locked <0x22ad0158> (a java.lang.Object)

线程获得了监视器<0x22ad0158>

二、- waiting to lock <0x22ad0160> (a java.lang.Object)

此线程不持有监视器<0x22ad0160>,但是它期待着获得监视器<0x22ad0160>

此线程是在“入口区”等待获取监视器<0x22ad0160>,即此线程不必等待其他线程执行<0x22ad0160>.notify()或<0x22ad0160>.notifyAll(),而是一旦<0x22ad0160>被其他线程释放掉(通过其他线程<0x22ad0160>.notify()或<0x22ad0160>.notifyAll(),或者其他线程<0x22ad0160>.wait()),此线程总是会去争抢<0x22ad0160>

三、- waiting on <0x22a15d48> (a java.lang.Object)

此线程刚刚执行了<0x22a15d48>.wait()后释放了监视器<0x22a15d48>,并期望再次获得<0x22a15d48>

此线程是在“等待区”等待获取监视器<0x22a15d48>,当然,再次获得时,需要其他线程调用<0x22a15d48>.notify()或<0x22a15d48>.notifyAll(),如果其他线程不调用<0x22a15d48>.notify()或<0x22a15d48>.notifyAll(),则此线程永远不会复活

在下面的语句中

synchronized (obj) {// waiting to lock <0x22a15d48>

while (!condition) {

obj.wait();//waiting on <0x22a15d48>(不再持有监视器了,在“等待区”期待着再次获得监视器)

}

// do when condition is OK

}

四、obj.wait()包含了两层含义:

1、  此线程释放了obj的监视器,即此线程现在已经不再持有obj的监视器啦

2、  在“等待区”等待着再次获取obj的监视器(其他线程必须调用obj.notify()或obj.notifyAll(),如果仅仅执行完成synchronized语句或synchronized块而没有调用obj.notify()或obj.notifyAll(),则“等待区”中的线程就永远不会苏醒)

五、线程的状态

1、  java.lang.Thread.State: RUNNABLE,此线程正在运行

2、  java.lang.Thread.State: WAITING,此线程位于“等待区”,等待其他线程调用<0x22a15d48>.notifyAll(),否则,这个线程永远不可能苏醒

3、  java.lang.Thread.State: BLOCKED,此线程位于“入口区”,且被阻塞了,在上面的例子中,死锁了,永远不会有解除block的机会(当然,在Java中,有些I/O方法也会阻塞的,不过,等到I/O完成后,就会自动解除block啦)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Java VisualVM是一种用于分析Java应用程序的工具,可以使用它来分析dump文件。以下是使用Java VisualVM分析dump文件的步骤: 1. 打开Java VisualVM并选择“File”菜单中的“Load”选项。 2. 选择要分析dump文件并加载它。 3. 在左侧的“Applications”窗口中选择要分析Java应用程序。 4. 在右侧的“Monitor”窗口中选择要分析的线程或进程,并查看其性能指标和堆栈跟踪信息。 5. 使用Java VisualVM提供的其他工具和插件来进一步分析和优化Java应用程序的性能。 总之,Java VisualVM是一种非常有用的工具,可以帮助开发人员诊断和解决Java应用程序的性能问题。 ### 回答2: Java VisualVM是一个Java虚拟机监视和分析工具。它提供了实时的应用程序性能监控,以及基于某些特定平台的内存和线程分析。使用Java VisualVM可以分析非常详细的诊断信息,它可以非常轻松地获取一个Java应用程序运行时的进程快照,即dump文件。在获取到dump文件后,我们可以通过Java VisualVM对dump文件进行分析,以更深入地了解应用程序的性能状况,从而提高程序的性能。下面我们来具体说明如何使用Java VisualVM分析dump文件。 在使用Java VisualVM分析dump文件之前,首先需要下载和安装Java VisualVM。Java VisualVM提供了以下两种方式来分析dump文件: 1.打开本地应用程序 打开Java VisualVM后,从菜单栏中点击File -> Load 即可打开本地应用程序,并可以在Applications选项卡中查看正在运行的Java进程。选取需要分析的进程,然后点击Snapshot按钮,即可生成dump文件。 2.分析远程应用程序 Java VisualVM还提供了通过JMX连接到远程应用程序获取dump文件的方式。选择File -> Add JMX Connection选项,并输入连接的IP地址和端口号。成功连接后,点击Applications选项卡,选择远程应用程序,然后点击Snapshot按钮即可生成dump文件。 在得到dump文件之后,我们可以通过Java VisualVM来进行性能分析。首先我们需要打开dump文件,选择File -> Load Snapshot,选择目标dump文件。在界面的左侧,我们可以看到以下五个选项卡: 1. Overview 用于查看堆内存和线程状况的概览。 2. Monitor 用于实时监控Java应用程序的性能和资源使用情况,如CPU、内存、线程等。 3. Heap Dump 用于查看内存快照中的详细信息,帮助找出内存泄漏和对象占用情况。 4. Threads 用于查看各个线程的状态和历史记录,并对线程进行诊断和采样。 5. Samples 用于对应用程序的性能瓶颈进行采样和分析,查找性能瓶颈和优化应用程序。 通过以上选项卡,我们可以对应用程序进行更加深入的性能分析,找出应用程序的性能瓶颈,帮助我们更好地优化应用程序的性能。 ### 回答3: Java VisualVM 是 Java 官方提供的一个性能分析工具,它可以通过连接远程或本地的 JVM 进程,收集各种性能相关的数据,包括堆内存、CPU、线程、GC 等。同时,Java VisualVM 还能够生成 Heap Dump 文件,用于分析内存泄露等问题。本文主要介绍如何使用 Java VisualVM 分析 Heap Dump 文件。 一、导出 Heap Dump 文件Java VisualVM 中,我们可以在“Applications” 中找到正在运行的 Java 应用程序,右键点击应用程序进程并选择“Heap Dump”即可生成 Heap Dump 文件,存放在本地文件系统中。该文件包含了 JVM 进程的整个内存快照,用于分析内存泄露、对象引用等问题。 二、分析 Heap Dump 文件 1. 打开 Heap Dump 文件 将 Heap Dump 文件导入到 Java VisualVM 中,可以通过“File”-”Load”-”Heap Dump”来打开。 2. 了解 Heap Dump 概要信息 通过查看 Heap Dump 的概要信息,可以了解到该应用程序的总内存使用量、对象个数、堆内存各区域的使用情况等。 3. 查看对象实例 在“Classes”标签页中,我们可以查看 Heap Dump 文件中所有的类,其中包含每个对象的实例数、占用内存大小等信息。可以通过该信息找到占用内存较大的对象,进一步分析其使用情况。 4. 分析对象引用 通过“References”标签页,我们可以查看各个对象之间的引用关系。可以通过该信息找到内存泄露的对象引用,找到引用该对象的对象,或使用MAT等工具分析该对象的引用链路,定位到引用根源。 5. 分析堆内存分布 通过“Heap Dump”标签页,我们可以查看堆内存分布情况。可以查看到堆内存各区域的内存大小及使用情况,从而了解内存的占用情况。 三、结论 本文介绍了如何使用 Java VisualVM 分析 Heap Dump 文件,通过了解对象实例、对象引用、堆内存分布等信息,找到内存泄露的对象,并定位到引用根源,进一步优化应用程序,提高其性能。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值