鍍金池/ 問答/Java  網(wǎng)絡安全/ 深入理解java虛擬機第二版 代碼清單3-1對于引用算法的驗證沒有輸出結果,與書

深入理解java虛擬機第二版 代碼清單3-1對于引用算法的驗證沒有輸出結果,與書上說明不符,為什么?

代碼如下:

package referenceCoutingGC;

/**
 * 
 * testGC()方法執(zhí)行后,ogjA和ogjB會不會被GC呢?
 *
 */
public class referenceCoutingGC {
    
    public Object instance = null;
    
    private static final int _1MB = 1024*1024;
    
    private byte[] bigSize = new byte[2*_1MB];
    
    public static void testGC(){
        referenceCoutingGC objA = new referenceCoutingGC();
        referenceCoutingGC objB = new referenceCoutingGC();
        objA.instance = objB;
        objB.instance = objA;
        
        objA = null;
        objB = null;
        
        //假設在這行放生GC,objA和objB是否能被回收?
        System.gc();
        System.out.println("??");
    }
    public static void main(String[] args){
        
        testGC();
        
    }
}

書上是有輸出結果的。 還特地說明4603k->210k的字眼。

我的是jdk 1.8

回答
編輯回答
孤客

他那個輸出是因為運行java時添加了運行參數(shù), 應該是-XX:+PrintGCDetails.
個人理解, 這一節(jié)只是一個簡介, 而這個例子只是想告訴你那兩個對象會被回收, 你可以暫時忽略這些日志, 有興趣可以在讀完這章以后再回頭看這些示例.
說的直白點, 即使你能讓程序輸出這些GC日志, 也不一定看得懂. 所以, 繼續(xù)往下讀吧.

2017年7月2日 05:51