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

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

背景

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

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

image.png

分析

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

解决方案

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

System.gc();

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

image.png

目录
相关文章
|
4月前
|
算法 Java
太狠了!阿里技术专家撰写的电子版JVM&G1 GC实战,颠覆了传统认知
JVM是Java语言可以跨平台、保持高发展的根本,没有了 JVM, Java语言将失去运行环境。针对 Java 程序的性能优化一定不可能避免针对JVM 的调优,随着 JVM 的不断发展,我们的应对措施也在不断地跟随、变化,内存的使用逐渐变得越来越复杂。所有高级语言都需要垃圾回收机制的保护,所以 GC 就是这么重要。
|
4月前
|
算法 Java
JVM GC和常见垃圾回收算法
JVM GC和常见垃圾回收算法
48 0
|
4月前
|
缓存 监控 算法
jvm性能调优实战 - 39一次大促导致的内存泄漏和Full GC优化
jvm性能调优实战 - 39一次大促导致的内存泄漏和Full GC优化
74 0
|
5月前
|
存储 缓存 算法
JVM(四):GC垃圾回收算法
JVM(四):GC垃圾回收算法
|
4月前
|
架构师 Java
jvm性能调优实战 - 35电商APP后台系统如何对Full GC进行深度优化
jvm性能调优实战 - 35电商APP后台系统如何对Full GC进行深度优化
52 0
|
4月前
|
存储 监控 算法
垃圾回收器、垃圾回收算法、空间分配担保、JVM调优、GC回收对象的过程
垃圾回收器、垃圾回收算法、空间分配担保、JVM调优、GC回收对象的过程
|
4月前
|
存储 分布式计算 前端开发
jvm性能调优实战 - 26一个每秒10万并发的系统如何频繁发生Young GC的
jvm性能调优实战 - 26一个每秒10万并发的系统如何频繁发生Young GC的
70 0
|
2月前
|
存储 算法 Java
精华推荐 | 【JVM深层系列】「GC底层调优专题」一文带你彻底加强夯实底层原理之GC垃圾回收技术的分析指南(GC原理透析)
精华推荐 | 【JVM深层系列】「GC底层调优专题」一文带你彻底加强夯实底层原理之GC垃圾回收技术的分析指南(GC原理透析)
57 0
|
3月前
|
算法 Java
深入理解JVM - 解读GC日志
深入理解JVM - 解读GC日志
52 0
|
4月前
|
算法 Java
JVM GC 垃圾回收
【1月更文挑战第3天】JVM GC 垃圾回收