java – 在显示分配堆栈跟踪时防止程序崩溃

为什么VisualVM在尝试查看对象分配堆栈跟踪时终止我的程序,我该如何解决?

我正在清理一个有一些内存问题的应用程序,最大的就是创建一堆短命的int []导致GC像疯了一样火:

java  – 在显示分配堆栈跟踪时防止程序崩溃

当我右键单击int []并选择Take Snapshot and Show Allocation Stack Traces时,我的应用程序关闭并弹出一个警告框,说明无法获取结果快照.申请终止:

07001

我在这个问题上找到的最接近的是一个错误报告recommended running my profiled application with -Xnoclassgc.它没有用,结果是一样的.

眼镜

VisualVM: 1.8.0_60 (Build 1380-140910); platform 20140910-unknown-revn
Java: 1.8.0_60; Java HotSpot(TM) 64-Bit Server VM (25.60-b23, mixed mode)
Eclipse: Luna Release (4.4.0) Build id: 20140612-0600
System: Windows 7 (6.1) Service Pack 1, amd64 64bit

崩溃日志

http://pastebin.com/a4YPWutj

崩溃日志的大小超出了字符限制,因此我不得不将其放在其他位置.抱歉.

解决方法:

好.因此,基于获得的crashlog,您看起来遇到了已在此处报告的VisualVM错误:

JVM being profiled crashes

原始bug的提交者将此行为缩小到Java8,因此您最好的机会是在较旧的(Java7)运行时上运行VisualVM.如果这是您的选项,那么您只需要下载Java7 JDK并直接从那里运行VisualVM.

上一篇:Gradle 发布 Jar 到 Archiva 时提示不能 Overwriting released


下一篇:sql server 事务隔离性 snapshot 、read committed说明