为什么 Young GC 比 Full GC 快
在 JVM 中,Young GC(Minor GC)比 Full GC 快很多,主要是因为两者在内存区域、回收对象的数量、算法复杂度等方面存在本质上的区别。
内存区域的区别
Young GC(Minor GC)只发生在新生代(Young Generation),回收新生代的短命对象(大多数对象在创建后很快就会被回收)。新生代的区域较小,通常只包含一些存活时间较短的对象,所以回收的时间较短。
Full GC 涉及整个堆内存,包括新生代、老年代(Old Generation)以及永久代(Metaspace)。Full GC 会回收整个堆中的所有对象,包括长寿命的对象,这些对象通常分布在老年代。老年代区域较大,回收时需要扫描和处理的对象更多,涉及到的区域更广。
垃圾回收算法的复杂度
Young GC 新生代通常采用复制算法(Copying Algorithm),即将存活的对象从 Eden 区和一个 Survivor 区复制到另一个 Survivor 区。复制算法的特点是简单、高效,只需要扫描存活的对象,未存活的对象直接被清除,因此回收速度很快。
Full GC 老年代通常采用的是标记-清除算法(Mark-Sweep)或标记-整理算法(Mark-Compact)。这些算法首先需要标记出所有的存活对象,然后再执行清除或整理。相比复制算法,标记-清除和标记-整理算法的执行过程复杂得多,尤其是标记和整理阶段会导致 Full GC 变慢。