背景
最近在验证 GC 的规则时,发现一个莫名其妙的现象,VM 配置如下,现象如图所示
-Xmx20m-Xms20m-Xmn7m-XX:+PrintGCDetails-XX:+PrintCommandLineFlags
分析
VM 配置很简单,新生代 7M 大小(可用空间 6656K + 512K),老年代大概就剩余 13M 左右,按照常识,我们都知道,给了 8M 的对象,按理讲新生代不够,直接晋升老年代才对,我们看图发现老年代的确进去了也是 8M,但是 eden 区的 44% 是啥子情况???
解决方案
在验证此类问题时,推荐在第一行加上
System.gc();
因为有些 IDEA 有自己的一套启动 GC 机制,可能启动的时候就会先进行 GC 先,之前也碰到过这样的案例,所以上面的情况也半斤八两,所以我们以后只要第一行代码先加入 FGC,到时候只要看 FGC 接下来的日志即可~ 如图所是,恢复正常!