Java 中的垃圾回收机制只作用域堆(Heap)和方法区中
Java虚拟机(JVM) 垃圾回收机制(GC)图解
JVM在进行GC时,并不是对这三个区域统一回收。大部分时候,回收的是新生代~

  • 新生代(Eden Space)
  • 幸存区(from,to)
  • 老年区

GC算法

  • 引用计数法
    Java虚拟机(JVM) 垃圾回收机制(GC)图解

  • 复制算法
    Java虚拟机(JVM) 垃圾回收机制(GC)图解
    每次GC后伊甸园区(Eden)和to区会是空的:
    Java虚拟机(JVM) 垃圾回收机制(GC)图解

    • 好处: 没有内存的碎片~
    • 坏处:浪费了内存空间~,多了一半空间永远是空 to。假设对象100%存活(极端情况)

复制算法最佳使用场景:对象存活度较低的时候;新生区~

  • 标记清除算法
    Java虚拟机(JVM) 垃圾回收机制(GC)图解

    • 优点:不需要额外的空间!
    • 缺点:两次扫描,严重浪费时间,会产生内存碎片。
  • 标记压缩算法
    Java虚拟机(JVM) 垃圾回收机制(GC)图解
    该算法解决了标记清除算法出现内存碎片的问题,但相应的时间成本也增加了。

总结

  • 内存效率 : 复制算法 > 标记清除算法 > 标记压缩算法 (时间复杂度)
  • 内存整齐度 : 复制算法 == 标记压缩算法 > 标记清除算法
  • 内存利用率 :标记清除算法==标记压缩算法 > 复制算法

没有最好的算法,只有最合适的算法:分代收集算法

年轻代

  • 存活率低 复制算法

老年代

  • 标记清除(内存碎片不是太多) + 标记压缩混合 实现

相关文章: