http://blogs.sun.com/fkieviet/entry/classloader_leaks_the_dreaded_java
http://www.zeroturnaround.com/blog/rjc201/
容器undeploy一个war时,是将该war的classloader置为null,以便GC回收,如果该war中的类或对象没有被外部引用的话,就能顺利的将该web程序的classloader及由它load的class全部回收。
但是,经常会不小心将web程序的对象引用传到外部去,例如
Level类在构造时,将生成的对象加入到了Level类的一个静态集合变量中保存起来
Level类是由JVM的类加载器加载的,对于WEB程序就属于外部,那么MyServlet$1对象的引用就被传递到了web程序外面,这导致redeploy该WAR的时候造成classloader的内存泄露
本文探讨了在容器重新部署Web应用程序时可能导致的类加载器内存泄漏问题。具体分析了一个Servlet示例,说明如何因不慎将Web程序对象引用传递到外部而导致Classloader无法被垃圾回收。
7425

被折叠的 条评论
为什么被折叠?



