深入理解JVM——关于垃圾回收

关于垃圾回收

 仿佛来自上海居委会大妈的灵魂拷问:“你是什么垃圾?”

今天我们要说的是JVM的垃圾回收

假如我是一个“人”类的“对象”,也和人的生命一样必有一死,可是“我真的还想再活500年~~”,面临着GC(垃圾回收器)这个“死神”,我可以逃脱命运的摆布吗?我应该如何逃脱呢?

其实是可以的,就是有名的finalize 大法(以前黑客常用的方法之一),下面代码演示一下:

/**
此代码演示:
1、对象可以在被GC时自救
2、这种自救的机会只有一次,因为一个对象的finalize()方法最多只会自动被系统调用一次
**/
public class FinalizeEscapeGC{
    public static FinalizeEscapeGC SAVE_HOOK=null;
    public void isAlive(){
        System.out.println("yes,i am still alive :)");
    }
    @override
    protected void finalize() throws Throwable{
        super.finalize();
        System.out.println("finalize method executed!");
        FinalizeEscapeGC.SAVE_HOOK=this;
    }
     
    public static void main(String[] args)throws Throwable{
        SAVE_HOOK=new FinalizeEscapeGC();
        //对象第一次成功拯救自己
        SAVE_HOOK=null;
        System.gc();
        //因为 finalize 方法优先级很低,所以暂等0.5秒
          Thread.sleep(500);
        if(SAVE_HOOK!=null){
            SAVE_HOOK.isAlive();
        }else{
            System.out.println("no,i am dead :(");
        }
         
        //这一次自救失败了,因为 finalize 方法只会调用一次哦
        SAVE_HOOK=null;
        System.gc();
        //因为 finalize 方法优先级很低,所以暂等0.5秒
        Thread.sleep(500);
        if(SAVE_HOOK!=null){
            SAVE_HOOK.isAlive();
        }else{
            System.out.println("no,i am dead :(");
        }
    }
}

注意,为了演示的理解性,2次自救代码是一样的

运行情况:

finalize method executed!
yes,i am alive :)
no,i am dead :(

第一次自救成功!!

第二次自救失败。。。

分析:

通过 finalize 这个门槛,我们可以逃脱,但是系统只会自动调用一次,所以要是在来一次就无法逃脱了。

但是 finalize 方法代价高昂,系统运行消耗内存资源,所以尽量不要使用。他可不是C/C++中的析构函数,只是当初为了让C程序员接受java的一个妥协。

所以,忘了他吧。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值