常见的垃圾回收算法
1、标记清除法(mark sweep) - 位置不连续,产生碎片,效率偏低(两遍扫描)
2、拷贝算法(copying) - 没有碎片,浪费空间
3、标记压缩(mark compact) - 没有碎片,效率偏低(两边扫描,指针需要调整)
以上的算法由古至今没变。目前常见的垃圾收集器
目前分代垃圾回收,用的最多jdk1.8常用组合是年轻代parallel scavenge和老年代parallel Old垃圾收集器(记忆ps+po)。
堆内存逻辑如下(jdk8进行jvm调优用G1即可)
只有G1是分区模型(jdk9默认是z1)
Serial - 单cpu效率最高虚拟机是client模式的默认垃圾回收器
a stop the world copying collector which users a single GC thread
ParNew - CMS(Concurrent mark sweep) 专门配合的, ParNew约等于Parallel Scavenge
JVM-垃圾收集器G1-笔记
最新推荐文章于 2023-12-02 22:17:00 发布
本文介绍了JVM的垃圾回收算法,包括标记清除、拷贝和标记压缩。重点讲解了JDK 1.8常用的Parallel Scavenge和Parallel Old垃圾收集器,以及G1收集器。G1采用分区模型,解决了CMS的漏标问题,并以三色标记和Stop-the-World策略实现高效回收。在使用G1时,应注意避免设置年轻代大小,让G1动态调整。最后提到了一些JVM调优相关的参数。
摘要由CSDN通过智能技术生成