package com.example.rubbish;
public class Rubbish {
private static int i=0; private int j = 0;
public Rubbish() {
// TODO Auto-generated constructor stub
j = i;
i++;
}
protected void finalize() {
System.out.println(j);
}
/** * @param args */
public static void main(String[] args) {
// TODO Auto-generated method stub
Object aobj = new Rubbish ( );
Object bobj = new Rubbish ( );
Object cobj = new Rubbish ( );
System.gc();
System.out.println("第三行垃圾处理");
aobj = bobj;
System.gc();
System.out.println("第四行垃圾处理");
aobj = cobj;
System.gc();
System.out.println("第五行垃圾处理");
cobj = null;
System.gc();
System.out.println("第六行垃圾处理");
aobj = null;
System.gc();
System.out.println("第七行垃圾处理");
}}
运行结果:
第三行垃圾处理
第四行垃圾处理
0
第五行垃圾处理
第六行垃圾处理
第七行垃圾处理
2
finalize()方法解释如下:
Java 技术允许使用 finalize() 方法在垃圾收集器将对象从内存中清除出去之前做必要的清理工作。这个方法是由垃圾收集器在确定这个对象没有被引用时对这个对象调用的。它是在 Object 类中定义的,因此所有的类都继承了它。子类覆盖 finalize() 方法以整理系统资源或者执行其他清理工作。finalize() 方法是在垃圾收集器删除对象之前对这个对象调用的。
Java中所有类都从Object类中继承finalize()方法。
当垃圾回收器(garbage colector)决定回收某对象时,就会运行该对象的finalize()方法。值得C++程序员注意的是,finalize()方法并不能等同与析构函数。Java中是没有析构函数的。C++的析构函数是在对象消亡时运行的。由于C++没有垃圾回收,对象空间手动回收,所以一旦对象用不到时,程序员就应当把它delete()掉。所以析构函数中经常做一些文件保存之类的收尾工作。但是在Java中很不幸,如果内存总是充足的,那么垃圾回收可能永远不会进行,也就是说filalize()可能永远不被执行,显然指望它做收尾工作是靠不住的。
那么finalize()究竟是做什么的呢?它最主要的用途是回收特殊渠道申请的内存。Java程序有垃圾回收器,所以一般情况下内存问题不用程序员操心。但有一种JNI(Java Native Interface)调用non-Java程序(C或C++),finalize()的工作就是回收这部分的内存。