H5W3
当前位置:H5W3 > 其他技术问题 > 正文

深入理解java虚拟机第二版 代码清单3-1对于引用算法的验证没有输出结果,与书上说明不符,为什么?

代码如下:

package referenceCoutingGC;

/**
 * 
 * testGC()方法执行后,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时添加了运行参数, 应该是-XX:+PrintGCDetails.
个人理解, 这一节只是一个简介, 而这个例子只是想告诉你那两个对象会被回收, 你可以暂时忽略这些日志, 有兴趣可以在读完这章以后再回头看这些示例.
说的直白点, 即使你能让程序输出这些GC日志, 也不一定看得懂. 所以, 继续往下读吧.

本文地址:H5W3 » 深入理解java虚拟机第二版 代码清单3-1对于引用算法的验证没有输出结果,与书上说明不符,为什么?

评论 0

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址