笔记:JVM垃圾回收机制
垃圾回收机制
GC发生在JVM什么位置
GC是发生在堆里面
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快速内存分配
标记清除(Mark-Sweep)
- 老年代一般是由标记清除或者标记清除与标记整理的混合实现
- 标记(Mark)
- 从根集合开始扫描,对存活的对象进行标记
- 从根集合开始扫描,对存活的对象进行标记
- 清除(Sweep)
- 扫描整个内存空间,收回未被标记的对象,使用free-list记录可以区域
- 扫描整个内存空间,收回未被标记的对象,使用free-list记录可以区域
- 优点:不需要额外空间
- 缺点:
- 两次扫描,耗时严重
- 会产生内存碎片
标记压缩(Mark-Compact)
- 发生在老年代
- 标记(Mark):与标记-清除一样
- - 压缩(Compact)
- 再次扫描,并往一端滑动存活对象
- 再次扫描,并往一端滑动存活对象
- 优点:没有内存碎片,可以利用bump-the-pointer
- 缺点:需要移动对象的成本