JVM GC Demo

package miaosha;

public class GCTest {

    private static final int SIZE = 6 * 1024 * 1024;

    public static void localVarGc1() {

        byte[] b = new byte[SIZE];

        System.gc();

    }

    public static void localVarGc2() {

        byte[] b = new byte[SIZE];

        b = null;

        System.gc();

    }

    public static void localVarGc3() {

        { byte[] b = new byte[SIZE];}

        System.gc();

    }

    public static void localVarGc4() {

        { byte[] b = new byte[SIZE]; }

        int c = 0;

        System.gc();

    }

    public static void localVarGc5() {

        localVarGc1();

        System.gc();

    }

    public static void main(String[] args) {

        // localVarGc1();

        // localVarGc2();

        // localVarGc3();

        // localVarGc4();

        localVarGc5(); }

}

localVarGc1:申请了一个6M大小的空间,赋值给b引用,然后调用gc函数,因为此时这个6M的空间还被b引用着,所以不能顺利gc;

localVarGc2:申请了一个6M大小的空间,赋值给b引用,然后将b重新赋值为null,此时这个6M的空间不再被b引用,所以可以顺利gc;

localVarGc3:申请了一个6M大小的空间,赋值给b引用,过了b的作用返回之后调用gc函数,但是因为此时b并没有被销毁,还存在于栈帧中,这个空间也还被b引用,所以不能顺利gc;

localVarGc4:申请了一个6M大小的空间,赋值给b引用,过了b的作用返回之后重新创建一个变量c,此时这个新的变量会复用已经失效的b变量的槽位,所以b被迫销毁了,所以6M的空间没有被任何变量引用,于是能够顺利gc;

localVarGc5:首先调用localVarGc1(),很显然不能顺利gc,函数调用结束之后再调用gc函数,此时因为localVarGc1这个函数的栈帧已经随着函数调用的结束而被销毁,b也就被销毁了,所以6M大小的空间不被任何对象引用,于是能够顺利gc。

详细请参考:

https://zhuanlan.zhihu.com/p/26331905

你可能感兴趣的:(JVM GC Demo)