0
点赞
收藏
分享

微信扫一扫

JVM - 验证 GC Demo 时必备的一个小技巧

背景

最近在验证 GC 的规则时,发现一个莫名其妙的现象,VM 配置如下,现象如图所示

-Xmx20m -Xms20m -Xmn7m -XX:+PrintGCDetails -XX:+PrintCommandLineFlags

JVM - 验证 GC Demo 时必备的一个小技巧_ide

分析

VM 配置很简单,新生代 7M 大小(可用空间 6656K + 512K),老年代大概就剩余 13M 左右,按照常识,我们都知道,给了 8M 的对象,按理讲新生代不够,直接晋升老年代才对,我们看图发现老年代的确进去了也是 8M,但是 eden 区的 44% 是啥子情况???

解决方案

在验证此类问题时,推荐在第一行加上

System.gc();

因为有些 IDEA 有自己的一套启动 GC 机制,可能启动的时候就会先进行 GC 先,之前也碰到过这样的案例,所以上面的情况也半斤八两,所以我们以后只要第一行代码先加入 FGC,到时候只要看 FGC 接下来的日志即可~ 如图所是,恢复正常!

JVM - 验证 GC Demo 时必备的一个小技巧_老年代_02


举报

相关推荐

0 条评论