Guice 3.0 + Tomcat 7.0 = ClassLoader内存泄漏

Guice 3.0 + Tomcat 7.0 = ClassLoader内存泄漏,第1张

Guice 3.0 + Tomcat 7.0 = ClassLoader内存泄漏

好吧,没有人在那里帮助我,所以这是我学到的东西:

终结线程由FinalizableReferenceQueue(FRQ)启动。MapMaker中有对FRQ的硬(静态)引用。WebAppClassLoader未被垃圾收集,因为由于硬引用,MapMaper仍然存在。

以下代码 解决了 我的问题:

final Class<?> queueHolderClass =     Class.forName("com.google.inject.internal.util.$MapMaker$QueueHolder");final Field queueField = queueHolderClass.getDeclaredField("queue");// make MapMaker.QueueHolder.queue accessiblequeueField.setAccessible(true);// remove the final modifier from MapMaker.QueueHolder.queuefinal Field modifiersField = Field.class.getDeclaredField("modifiers");modifiersField.setAccessible(true);modifiersField.setInt(queueField, queueField.getModifiers() & ~Modifier.FINAL);// set it to nullqueueField.set(null, null);

这是 令人反感的 代码(

com.google.inject.internal.util.MapMaker
):

private static class QueueHolder {  static final FinalizableReferenceQueue queue = new FinalizableReferenceQueue();}

完成此 *** 作后,终结器线程正常退出。



欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5442286.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-11
下一篇 2022-12-11

发表评论

登录后才能评论

评论列表(0条)

保存