Effective Java(Java中的finalize与垃圾回收机制)

在第7条避免使用终结方法中提到的finalize(),于是在查阅finalize()的时候有提到了垃圾回收机制,便一起阅读以下,记下一点笔记


当一个对象没有任何引用指向的时候,此时就可能会被垃圾回收,一旦垃圾回收期准备好释放对象占用的存储空间时,首先调用finalize()的方法,并且在下一次的垃圾回收动作发生时,才会真正的回收对象占用的内存,因此在finalize()里面可以做一些重要的清理工作。

来及回收期准备释放内存的时候,会先调用finalize(),对此有如下几点:

<1>对象不一定会被回收

<2>垃圾回收不是析构函数

<3>垃圾回收只与内存有关

<4>垃圾回收和finalize()都是靠不住的,只要JVM还没有到快耗尽内存的地步,它是不会浪费时间进行垃圾回收的


如同第7条中提到的一样,我们并不知道finalize()方法的调用会发生在什么时候,这样会很浪费时间,当要调用finalize()的时候使用System.gc或者直接调用finalize()方法

下面举个例子吧

在一个类中重载finalize()方法(是Object的方法),当使其对象的引用不存在时,是否会调用该方法

public class PersonCheck {
 
	public static int fir=0;
	public static final int id=++fir;
	
	@Override
	protected void finalize() throws Throwable {
		// TODO Auto-generated method stub
		super.finalize();
		System.out.println(this.getClass()+": id="+id+" is finalized");
	}
	
	public PersonCheck(){
		System.out.println("id="+id+" is created");
	}
}


在另一个类中实例化上面的类,并让其引用为空,但是打印的结果中并没有调用finalize()方法,就如上面所述,垃圾回收器只有在内存不够的时候才会调用。

public class PersonCheckTest {

	public static void main(String[] args) {
		PersonCheck personCheck1=new PersonCheck();
		PersonCheck personCheck2=new PersonCheck();
		PersonCheck personCheck3=new PersonCheck();
		
		personCheck1=personCheck2=null;
		
		System.gc();
	}
}
于是我强制调用System.gc(),结果finalize()方法才被调用,显示如下

id=1 is created
id=1 is created
class com.effectivejava.PersonCheck: id=1 is finalized
class com.effectivejava.PersonCheck: id=1 is finalized


具体的垃圾回收机制就不记述了

参考:

http://blog.sina.com.cn/s/blog_72827fb10101eqo5.html

http://my.oschina.net/u/2297250/blog/383407

http://www.cnblogs.com/hnrainll/archive/2013/11/06/3410042.html

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值