题
为什么VisualVM在尝试查看对象分配堆栈跟踪时终止我的程序,我该如何解决?
我正在清理一个有一些内存问题的应用程序,最大的就是创建一堆短命的int []导致GC像疯了一样火:
当我右键单击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
崩溃日志
崩溃日志的大小超出了字符限制,因此我不得不将其放在其他位置.抱歉.
解决方法:
好.因此,基于获得的crashlog,您看起来遇到了已在此处报告的VisualVM错误:
原始bug的提交者将此行为缩小到Java8,因此您最好的机会是在较旧的(Java7)运行时上运行VisualVM.如果这是您的选项,那么您只需要下载Java7 JDK并直接从那里运行VisualVM.