Java中的内存泄露(转)
来源:互联网 发布:生鲜app源码 编辑:程序博客网 时间:2024/05/16 03:22
java导致内存泄露的原因很明确:长生命周期的对象持有短生命周期对象的引用就很可能发生内存泄露,尽管短生命周期对象已经不再需要,但是因为长生命周期对象持有它的引用而导致不能被回收,这就是java中内存泄露的发生场景。
1.集合类,集合类仅仅有添加元素的方法,而没有相应的删除机制,导致内存被占用。这一点其实也不明确,这个集合类如果仅仅是局部变量,根本不会造成内存泄露,在方法栈退出后就没有引用了会被jvm正常回收。而如果这个集合类是全局性的变量(比如类中的静态属性,全局性的map等即有静态引用或final一直指向它),那么没有相应的删除机制,很可能导致集合所占用的内存只增不减,因此提供这样的删除机制或者定期清除策略非常必要。
2.单例模式。不正确使用单例模式是引起内存泄露的一个常见问题,单例对象在被初始化后将在JVM的整个生命周期中存在(以静态变量的方式),如果单例对象持有外部对象的引用,那么这个外部对象将不能被jvm正常回收,导致内存泄露,考虑下面的例子:
class A{
public A(){
B.getInstance().setA(this);
}
....
}
//B类采用单例模式
class B{
private A a;
private static B instance=new B();
public B(){}
public static B getInstance(){
return instance;
}
public void setA(A a){
this.a=a;
}
//getter...
}
显然B采用singleton模式,他持有一个A对象的引用,而这个A类的对象将不能被回收。想象下如果A是个比较大的对象或者集合类型会发生什么情况。
上面所讲的这些也启发我们如何去查找内存泄露问题,在代码复审的时候关注长生命周期对象:全局性的集合、单例模式的使用、类的static变量等等。在Java的实现过程中,也要考虑其对象释放,最好的方法是在不使用某对象时,显式地将此对象赋空。最好遵循谁创建谁释放的原则。
本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/yakihappy/archive/2009/03/11/3979942.aspx
- Java中的内存泄露(转)
- (转)JAVA中的内存泄露
- (转)JAVA中的内存泄露
- java中的内存泄露
- Java中的内存泄露
- Java中的内存泄露
- java 中的内存泄露
- (面试题)Java中的内存泄露
- java中的内存泄露情况
- Java中的内存泄露问题
- 诊断Java中的内存泄露
- 诊断Java中的内存泄露
- 诊断Java中的内存泄露
- 诊断Java中的内存泄露
- 诊断Java中的内存泄露
- 诊断Java中的内存泄露
- 什么是Java中的内存泄露
- K:java中的内存泄露
- How to disable “Billing Agreements” and “Recurring Profiles”
- shell脚本中if的参数
- ASP.NET中JSON的序列化和反序列化
- 探秘widget之widget背后的故事
- struts2文件下载错误提示的解决方法
- Java中的内存泄露(转)
- windows全局消息钩子的一个BUG
- 27 款经典的CSS 框架
- Null value was assigned to a property of primitive type setter of
- iOS SDK 4.3 学习笔记 iPhone101 (01)
- android 自定义ListView 实现 弹出自定义对话框(带EditText)实现 配置文件实现
- 关于解决Domino web服务器(HTTP)宕机和挂起的问题
- ANSI 和 UNICODE 的函数对应表
- Spring中启用AOP时要使用ApplicationContext而不要使用XmlBeanFactory