JAVA内存泄漏

错误严重度

如果内存泄漏面积过大,将会导致B类或A类故障

错误案例

public class Stack
{
    private Object[] elements;
    private int size = 0;
 
    public Stack(int i)
    {
        this.elements = new Object[i]; 
    } 
 
    public void push(Object e)
    {
        ensure();
        elements[size++] = e; 
    }
 
    public Object pop()
    {
        if(size == 0)
        {
             
        } 
  
        return elements[size--];
    }
 
    private void ensure()
    {
         
    }
}

错误分析

一般来说,Java的垃圾回收机制解决了大部分的内存泄漏问题,但这并不等于Java中的不存在内存泄漏。

Java中的内存泄漏主要是指对象被不合理的长期持有。

例如,上述用法中,标红的地方存在着内存泄漏的问题,因为当它被弹出堆栈(size--)的时候,elements[size]对象已无法通过正常的途径来访问;但同时,它也没有成为可回收的垃圾对象,因为Stack维护着他们的绝对的引用。假设在stack中放入大量对象,之后又通过pop()方法逐一弹出,此时stack对象仍占据大量垃圾对象,直到整个Stack被销毁。

因此,在内存消耗过大的时候,可以检查在用JAVA集合类(特别是hashmap)的时候,是否有大量对象被不合理的长期持有。


正确用法

……
public Object pop()
{
    if(size == 0)
    {
         
    } 
    Object obj = elements[--size];
    elements[size] = null;
  
    return obj;
}
……


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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值