关于java:GC垃圾回收机制基本过程理解

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()==");
    }
}

运行成果:
如下图所示:

评论

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

这个站点使用 Akismet 来减少垃圾评论。了解你的评论数据如何被处理