java 调用dll内存泄露_Java中常见的内存泄露出现的方式

本文探讨了Java中调用DLL可能导致的内存泄露问题,包括长生命周期对象持有短生命周期对象引用、集合类内存泄露、监听器未移除、未关闭的连接以及单例模式不当使用等具体情况。特别强调了数据库和网络连接的显式关闭以及单例模式中对外部对象引用的管理,以防止内存资源无法释放。
摘要由CSDN通过智能技术生成

1:根本原因

长生命周期的对象持有短生命周期对象的引用会导致内存泄露。这是因为虽然短生命周期的对象已经没有了外部引用,可以被i释放了,但是被长生命周期的对象持有,不能释放。

2:具体情况

2.1:集合类引起内存泄露

比如:集合类中存放指定对象,但是对象引用已经失效,由于对象存放在集合中,所以无法释放该对象的内存。

ArrayList al = new ArrayList(10);for(int i=0;i<10;i++){

Object obj= newObject();

al.add(obj);

obj= null;

}

2.2:监听器

在java 编程中,我们都需要和监听器打交道,通常一个应用当中会用到很多监听器,我们会调用一个控件的诸如addXXXListener()等方法来增加监听器,但往往在释放对象的时候却没有记住去删除这些监听器,从而增加了内存泄漏的机会

2.3:各种连接

比如数据库连接(dataSourse.getConnection()),网络连接(socket)和io连接,除非其显式的调用了其close()方法将其连接关闭,否则是不会自动被GC 回收的。对于Resultset 和Statement 对象可以不进行显式回收,但Connection 一定要显式回收,因为Connection 在任何时候都无法自动回收,而Connection一旦回收,Resultset 和Statement 对象就会立即为NULL。但是如果使用连接池,情况就不一样了,除了要显式地关闭连接,还必须显式地关闭Resultset Statement 对象(关闭其中一个,另外一个也会关闭),否则就会造成大量的Statement 对象无法释放,从而引起内存泄漏。这种情况下一般都会在try里面去的连接,在finally里面释放连接。

2.4:单例模式

如果单例对象持有外部对象的引用,那么这个外部对象将不能被jvm正常回收,导致内存泄露

不正确使用单例模式是引起内存泄露的一个常见问题,单例对象在被初始化后将在JVM的整个生命周期中存在(以静态变量的方式),如果单例对象持有外部对象的引用,那么这个外部对象将不能被jvm正常回收,导致内存泄露,考虑下面的例子:

classA{publicA(){

B.getInstance().setA(this);

}

....

}//B类采用单例模式

classB{privateA a;private static B instance=newB();publicB(){}public staticB getInstance(){returninstance;

}public voidsetA(A a){this.a=a;

}//getter...

}

A类的对象将无法被GC回收!!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值