第6条:消除过期的对象引用

Java的垃圾回收固然省事,然而这并不代表着程序员不需要考虑内存管理。

例如,下面是一个粗心的栈实现代码,直接贴有错误的部分

public class Stack{
    //省略。。。。。

    //有误代码
    public Object pop(){
        if(size == 0){
            throw new EmptyStackException();
        }
        return elements[--size];
    }
    //省略。。。。。
}

这段代码并没有明显的错误。不严格地说,它有一个“内存泄露”风险,因为在执行pop这个方法后没有把弹出对象设置为null(此时这个对象对于栈来说是过期的引用)
改进自然就是这样:

public Object pop(){
        if(size == 0){
            throw new EmptyStackException();
        }
        Object result =  elements[--size];
        elements[size] == null;//解除过期引用
        return result;
    }

那我们自然会有困惑,按照这样发展,每次程序员都要关注引用是否过期,然后手动解除,这样不就不符合java自动垃圾回收的思想了吗?

所以,一般而言,只要类是自己管理内存,程序员就应该警惕内存泄露的问题

那么类怎样才算是自己管理内存

例:上面的Stack类的存储池(storage pool)中包含了elements数组(对象引用单元,而不是对象本身)的元素。数组活动区域中的元素是已分配(allocated)的,而数组其余部分的元素是自由的(free)。

即根据栈的定义,下标大于size-1的元素(栈元素从下标0开始)是不在栈中的。

然而垃圾回收器并不知道这一点,对于垃圾收集齐而言,elements里的所有对象都是有效的。

这时就需要程序眼手工清空这些数组元素

未完—————————

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值