1.分代收集理论:
垃圾收集器一般都采用分代收集算法,可以根据对象存活周期的不同将内存分为几块,一般都是把java堆分为年轻代和老年代,可以根据各个年代的特点选择合适的垃圾收集算法。
2.标记复制算法:
此种算法可以解决效率问题。它将内存分为大小相同的两块,每次使用其中的一块,当这一块的内存使用完以后,就将还存活的对象复制到另外一块去,然后再把使用的空间一次清理掉。每次内存的回收都是对内存的一半进行回收。
3.标记清除算法:
该算法分为标记和清除两个阶段,标记存活的对象,统一回收所有没有被标记的对象;也可以反过来,标记处所有需要回收的对象,在标记完成后,统一回收所有被标记的对象。这个是最基础的收集算法,但又如下缺点:
1.效率不高,如果标记的对象太多就不好
2.空间问题,标记清除后,会产生大量不连续的 碎片。
4.标记整理算法
根据老年代的 特点推出的一种算法,标记过程和标记清除算法差不多,但是后续步骤不是对可回收对象进行回收,而是让所有存活的对象移到一段,然后清理掉边界以外的内存。