GC
GC全拼是Garbage Collectio,是指计算机技术中的垃圾回收零碎,Java语言就是自带垃圾回收零碎的一门语言,那么在程序运行中,到底是怎么回收的呢?
何为垃圾?
要理解java中的GC垃圾回收零碎,当然要先了解在java中什么样的数据或对象会被GC断定为"垃圾".
可达性:
首先须要理解一个概念,叫做"可达性"
class ClassA{}public class TestGC{ ClassA class1 = new ClassA();}
在下面这行简略易懂的代码中,咱们能够看到new出的ClassA对象是被后面的"ClassA class1"所援用的.
当对象实例有援用指向时,就是指这个对象"可达";
class ClassA{}public class TestGC{ ClassA class1 = new ClassA(); class1 = null;}
而如果咱们将这个申明指向null,且在这个类中没有其余的援用去指向之前的"new ClassA()",那它就是"不可达的".
当没有任何援用(如:池中是否有该对象)指向此对象,就是指这个对象"不可达",这时这个对象就会被JVM认为是"垃圾".
GC零碎回收的启动
GC零碎回收的启动形式分为两种:手动启动/主动启动
手动启动:
通过"System.gc();"语句来手动开始GC.
当你开启GC,且"System.gc();"之前存在"垃圾对象",那么就会对"垃圾对象"进行销毁回收,开释内存资源.
class ClassA{}public class TestGC{ ClassA class1 = new ClassA(); class1 = null; System.gc();}
主动启动:
零碎底层会随着创建对象的减少,占用内存的减少,基于内存状况,来主动启动GC.
简而言之,就是内存不足时,会主动开启GC,如果之前存在"垃圾对象",那么就会对"垃圾对象"进行销毁回收,开释内存资源.
class ClassA{}public class TestGC{ ClassA class1 = new ClassA(); class1 = null; List<byte[]> list=new ArrayList<>(); for(int i=0;i<100000;i++) { list.add(new byte[1024*1024]); }}
在上述代码中,通过创立汇合,且一直向其中增加数组的模式,来模仿内存不足,主动开启GC的状况,当这种状况产生时,且class1指向null,new ClassA()没有援用指向,GC就会主动将垃圾对象--new ClassA()进行回收开释内存.
测试运行
当咱们在运行上述代码时,如果是这样运行,运行后果是空白的,看不出到底GC有没有启动.
GC是否启动:
通过配置JVM参数:
在类中右键->Run As->Run Configurations->Arguments->VM arguments中输出:-XX:+PrintGC
配置后在控制台中,就能够看到GC启动的成果
对象是否被GC:
在对象类中,通过重写Object类的finalize办法进行显示
class ClassA{ /**对象在被回收前会执行此办法*/ @Override protected void finalize() throws Throwable { System.out.println("==finalize()=="); }}
运行成果:
如下图所示: