JAVA中常见的垃圾回收算法
在Java中,常见的垃圾收集算法包括:
- 标记-清除(Mark-Sweep): 这是最基本的垃圾收集算法,包括两个阶段,标记和清除。首先标记出所有需要回收的对象,然后统一回收被标记的对象。此算法简单,但会产生大量不连续的内存碎片。
- (Copying): 为了解决标记-清除算法的内存碎片问题,出现了复制算法。它将可用内存分为两块相等的区域,每次只使用其中一块。当这一块内存用完了,就将还存活的对象复制到另一块上去,然后把已使用的内存空间一次性清理掉。这种算法实现简单,运行高效,但是代价是内存被大幅缩小。
- 标记-整理(Mark-Compact): 为了解决复制算法带来的内存缩小问题,标记-整理算法就被提了出来。它在标记阶段还是和标记-清除一样,但是在清理阶段不是直接清理,而是让所有存活的对象都向一端移动,然后直接清理掉端边界以外的内存。
- 分代收集(Generational Collector): 基于对象生命周期的不同,分代收集算法将堆分为新生代和老年代。新生代中,大部分对象都是朝生夕死,所以用复制算法,效率高。而老年代中对象存活率高,一般用标记-整理或标记-清除算法。
Java中常用的垃圾收集器包括:Serial GC、Parallel GC、Parallel Old GC、G1 GC、ZGC等。不同的垃圾收集器可能采用了上述不同的算法,或者是它们的组合。
评论已关闭