深入理解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的一个妥协。
所以,忘了他吧。