深入理解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的一个妥协。

所以,忘了他吧。

 

posted on 2019-07-09 15:33  乌云上  阅读(153)  评论(0编辑  收藏  举报

导航