一 点睛
当一个对象失去引用后,系统何时调用它的finalize()方法对它进行资源清理,何时它可以变成不可达状态,系统何时回收它占有的内存,对于程序完全透明。程序只能控制一个对象不再被任何引用变量引用,不能控制它何时被回收。
程序可以强制系统进行垃圾回收——这种强制只是通知系统进行垃圾回收,但系统是否进行垃圾回收依然不能确定。大部分时候,程序强制垃圾回收后总是有一些效果
强制系统垃圾回收有如下两个方法:
-
调用System类的gc()静态方法:System.gc()
-
调用Runtime对象的gc()实例方法:Runtime.getRuntime().gc()
二不强制进行垃圾回收代码
1 代码
public class GcTest
{
public static void main(String[] args)
{
for (int i = 0 ; i < 1; i++)
{
new GcTest();
}
}
public void finalize()
{
System.out.println("系统正在清理GcTest对象的资源...");
}
}
2 运行
程序运行无任何结果。
3 说明
程序创建了1个匿名对象,这个对象在创建之后立即进入可恢复状态,等待系统回收,但直到程序退出,系统依然不能回收该资源。
三 强制垃圾回收代码
1 代码
public class GcTest
{
public static void main(String[] args)
{
for (int i = 0 ; i < 1; i++)
{
new GcTest();
// 下面两行代码的作用完全相同,强制系统进行垃圾回收
// System.gc();
Runtime.getRuntime().gc();
}
}
public void finalize()
{
System.out.println("系统正在清理GcTest对象的资源...");
}
}
2 运行
系统正在清理GcTest对象的资源...
3 说明
该打印说明强制垃圾回收起了作用。
命令行执行如下语句后,可以看到垃圾回收前、回收后的内存占用对比。
E:\Java\IDEA_Java\out\production\IDEA_Java>java -verbose:gc GcTest
[GC (System.gc()) 2621K->760K(251392K), 0.0009908 secs]
[Full GC (System.gc()) 760K->670K(251392K), 0.0040659 secs]
系统正在清理GcTest对象的资源...
运行结果显示了程序强制垃圾回收的效果,但这种强制只是建议系统立即进行垃圾回收,系统完全有可能并不立即进行垃圾回收,垃圾回收机制也不会对程序的建议完全置之不理;垃圾回收机制会在收到通知后,尽快进行垃圾回收。