- 在默认情况下,通过System.gc( )或者Runtime.getRuntime( ).gc( )的调用,会显示出发Full GC,同时对老年代和新生代进行回收,尝试释放被丢弃对象占用的内存
- 然而,System.gc( )调用附带一个免责申明,无法保证对垃圾收集器的调用。如下代码,多次运行main方法,并不会保证每次TestSystemGC中的finalize方法被调用(关于对象的finalization机制可以参考:https://blog.csdn.net/qq_27062249/article/details/117793685)
public class TestSystemGC {
public static void main(String[] args) {
new TestSystemGC(); //提醒JVM的垃圾收集器执行gc操作,但不确保一定会执行
System.gc();
//System.runFinalization(); //强制调用失去引用对象的finalize方法
}
@Override
protected void finalize() throws Throwable {
super.finalize();
System.out.println("TestSystemGC重写的finalize方法被执行了!!!");
}
}
- JVM实现者可以通过System.gc( )调用来决定JVM的GC行为。而一般情况下,垃圾回收应该是自动进行的,无需手动触发,否则就太过于麻烦了。在一些特殊情况下,如我们编写一个性能基准,我们可以在运行之间调用System.gc ( )