我有一个基于NetBeans RCP的应用程序,显然只在一些PC上,只有有时,只是冻结后,打开一个新的TopComponent。老实说,我从来没有看过JVM线程转储,但我真的不知道可能会发生什么。不幸的是,我不知道线程转储文件是否完整,因为jstack在尝试生成转储时会产生以下异常:
Attaching to core c:\bas.txt from executable 8836, please wait...
Error attaching to core file: Windbg Error: OpenDumpFile failed!
sun.jvm.hotspot.debugger.DebuggerException: Windbg Error: OpenDumpFile failed!
at sun.jvm.hotspot.debugger.windbg.WindbgDebuggerLocal.attach0(Native Method)
at sun.jvm.hotspot.debugger.windbg.WindbgDebuggerLocal.attach(WindbgDebuggerLocal.java:160)
at sun.jvm.hotspot.HotSpotAgent.attachDebugger(HotSpotAgent.java:673)
at sun.jvm.hotspot.HotSpotAgent.setupDebuggerWin32(HotSpotAgent.java:569)
at sun.jvm.hotspot.HotSpotAgent.setupDebugger(HotSpotAgent.java:335)
at sun.jvm.hotspot.HotSpotAgent.go(HotSpotAgent.java:304)
at sun.jvm.hotspot.HotSpotAgent.attach(HotSpotAgent.java:156)
at sun.jvm.hotspot.tools.Tool.start(Tool.java:191)
at sun.jvm.hotspot.tools.Tool.execute(Tool.java:118)
at sun.jvm.hotspot.tools.JStack.main(JStack.java:92)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:497)
at sun.tools.jstack.JStack.runJStackTool(JStack.java:140)
at sun.tools.jstack.JStack.main(JStack.java:106)因此,我设法用控制台窗口启动了我的RCP应用程序,并在它挂起时按下了CTRL+break。如上所述,我不能确定它是否完整,因为控制台窗口可能有更多从缓冲区中删除的行。
无论如何,这是指向转储文件的链接(我手动添加了第一行,以便在线程转储分析器中打开它):
http://pastebin.com/1M5T85i5
有人能帮我理解一下吗?
谢谢
发布于 2016-07-16 03:27:09
这听起来像是死结。诊断死锁的最简单方法是使用JConsole (包含在JDK中)连接到Java程序,并使用检测死锁功能。
https://stackoverflow.com/questions/37077979
复制相似问题