垃圾收集算法
- 标记清除法
- 复制法
- 标记整理法
- 分代收集法
缺点
- 标记清除法:
原理: 从根开始扫描,标记所有的存活对象(可达对象),然后对所有未标记的对象进行清除操作。
缺点: 清除后会产生不连续内存,内存碎片,导致资源浪费。 - 复制法:
原理: 把一块区域切分成2份,从s1把所有存活对象进行复制到s2区域,然后把s1的清除。
缺点: 资源分为2块,运行时只使用一份区域,另一个区域空闲,导致资源浪费。 - 标记整理法:
原理: 扫描标记与标记清除法一样,但是他在清除前还有一步,整理步骤。首先对存活对象进行标记,然后对标记对像向一端进行移动整理,然后清除另一端。
缺点: 步骤添加,所以性能消耗会大
分代收集法
分为年轻代,老年代。
年轻代:垃圾回收时都会对很大一部分对象进行回收,所以内存占用比较小,而且gc频率会略高。一般会使用复制法。
老年代:垃圾回收时,一般都是较小的进行回收,因为到老年代的对象,一般都是默认经过15次回收才到老年代,所以大部分都是使用中。一般会使用标记清除或标记整理法。
垃圾回收器产品
- serial 使用在年轻代,串行gc
- ParNew 使用在年轻代,并行gc
- Parallel Scavenge 使用在年轻代,并行gc
- serial old 使用在老年代,串行gc
- parallel old 使用在老年代,并行gc
- cms 使用在老年代,并发gc(据说能做还可以设置还精准stw的时间)
serial会与serial old或cms搭配使用
parnew会与serial old 或cms搭配使用
parallel scavenge会与parallel old搭配使用