笔记:JVM垃圾回收机制

GC发生在JVM什么位置

GC是发生在堆里面

笔记:JVM垃圾回收机制

GC(分代收集算法)的分类

  • 次数频繁收集年轻区 Young区—— Minor GC
  • 次数上较少收集老年区Old区—— Full GC
  • 基本不动永久区 Perm区

GC 的算法

引用计数法

  • 对象互相之间有引用,GC就不进行垃圾回收
  • 缺点:
    • 每次对对象赋值时均要维护引用计数器,且计数器本身也有一定的消耗
    • 较难处理循环引用
  • JVM的实现一般不采用这种方式,已经淘汰

复制算法(Coping)

  • 发生在年轻代 Minor GC
  • 原理:
    • 从根基合(GC ROOT)开始,通过Tracing从From中找到存活对象,拷贝到To总
    • From、To交换身份,下次内存分配从To开始
  • 缺点:需要双倍空间
  • 优点:
    • 效率高,没有标记和清除的过程
    • 快速分配内存,没有内存碎片,可利用bump-the-pointer快速内存分配
    • 笔记:JVM垃圾回收机制

标记清除(Mark-Sweep)

  • 老年代一般是由标记清除或者标记清除与标记整理的混合实现
  • 标记(Mark)
    • 从根集合开始扫描,对存活的对象进行标记
      笔记:JVM垃圾回收机制
  • 清除(Sweep)
    • 扫描整个内存空间,收回未被标记的对象,使用free-list记录可以区域
      笔记:JVM垃圾回收机制
  • 优点:不需要额外空间
  • 缺点:
    • 两次扫描,耗时严重
    • 会产生内存碎片

标记压缩(Mark-Compact)

  • 发生在老年代
  • 标记(Mark):与标记-清除一样
    -笔记:JVM垃圾回收机制
  • 压缩(Compact)
    • 再次扫描,并往一端滑动存活对象
      笔记:JVM垃圾回收机制
  • 优点:没有内存碎片,可以利用bump-the-pointer
  • 缺点:需要移动对象的成本

标记清除压缩(Mark-Sweep-Compact)