您可以尝试java.lang.Runtime.addShutdownHook(),并使该钩子遍历所有线程,并使用Thread.getAllStackTraces()转储其堆栈跟踪。但是,如果JVM已关闭,
Runtime.halt()则不会调用该挂钩。更为复杂的是使用工具挂接到对
Runtime.exit()和的调用
Runtime.halt()(或
Shutdown.sequence(),请参阅编辑#2),这样您就可以准确地看到在调用两者时发生的情况。
编辑
:做这将是安装的另一种方式安全管理器,只要它不执行任何安全性,但它转储线程列表
SecurityManager.checkExit()被调用,因为两者
halt()并
exit()调用安全管理方法。这将比使用检测工具容易得多,并且您甚至可以决定在记录线程正在执行的 *** 作之外引发异常。
编辑2 :运行JVM的系统可以告诉JVM终止,在这种情况下,使用安全管理器将无法工作。也不会在
Runtime.exit()or
上使用检测
Runtime.halt(),因为调用的方法是
java.lang.Shutdown.exit()。如果由于最后一个守护程序线程完成而关闭了JVM,则将
Shutdown.shutdown()调用它。但是关闭挂钩
将 在两种情况下 都 起作用。因此,即使您还将使用安全管理器或工具,也应始终使用关闭挂钩。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)