分代收集
弱分代:绝大多数对象都是朝生夕灭的。
强分代:熬过越多次垃圾收集过程的对象就越难以消亡。
在Java中,垃圾收集器将Java堆划分出不同的区域,将对象根据不同的年龄分配到不同区域。根据不同的区域,划分不同的回收类型。针对不同的区域及存储对象存储特征,推出不同的垃圾收集算法,“标记清除算法”、“标记复制算法”、“标记整理算法”。
部分收集(Partial GC):只对Java堆中的部分区域进行垃圾回收,部分收集又划分为新生代收集、老年代收集、混合收集
- 新生代收集(Minor GC/Young GC):只对新生代区域进行垃圾回收。
- 老年代收集(Major GC/Old GC):只对老年代进行垃圾回收。
- 混合收集(Mixed GC):对整个新生代及部分老年代进行垃圾回收。目前只有G1收集器会有这种行为
整堆收集(Full GC):对整个Java堆和方法区的进行垃圾回收
标记清除算法
该算法分为“标记”和“清除”两个阶段:首先标记出所有需要回收的对象,在标记完成后,统一回收掉所有被标记的对象。
该算法效率会随着需要被回收对象的数量增加而降低;并且会存在空间碎片化问题,即:标记清除后会产生不连续的内存碎片。
标记复制算法
该算法将内存划分为大小相等的两块,每次只使用其中一块。比如现在分为a、b两块区域,a区为保留区域,b区为使用区域,当b区区域空间不足时,将存活的对象从b区复制到a区,再将b区对象清除。
该算法避免空间碎片化问题,并且将对象重新分配内存时只需要移动指针,实现简单高效。其缺陷也显而易见,因为需要保留一块空间,需要使用的空间是其他算法的两倍。
标记整理算法
该算法标记与标记清除算法一样,但是后续并不是直接对标记的对象进行回收,而是让所有存活的对象都像一边移动,然后清理掉边界以外的内存。
下一章对HotSpot算法进行介绍分析,谢谢观看。