Java中对于垃圾回收的策略有多种,而目前商业虚拟机的垃圾收集都采用“分代收集”,这种算法是根据对象存活周期的不同将内存分为几块,一般是将Java堆分为新生代和老年代,根据各个年代的特点采用较适合的收集算法。
新生代中采用的收集算法:复制算法。算法的思想是将可用内存分为大小相等的两块,每次使用其中一块,当一块内存用完了,就将还存活的对象分到另一块。然后把使用过的内存空间一次进行清理。这种算法缺点会明显,就是会浪费一半的空间。而根据IBM研究表明,新生代中98%的对象朝生夕死,所以不需要按照1:1进行分配,而是按照内存分为一块较大的Eden空间和两块较小的Survivor空间(from和to两个),每次使用Eden和其中一个Survivor。当回收时,将Eden和其中一块Survivor中还存活着的对象一次性复制到另一块Survivor中,然后清理Eden和刚才用过的Survivor空间。一般默认的比例为:Eden:from:to=8:1:1。注:可通过-XX:SurvivorRatio=i来设置,默认i=8。当Survivor空间不够时,需要依赖其他内存(老年代)进行分配担保。内存的分配担保:如果另一块Survivor空间没有足够的内存空间存放上一次新生代收集下来的存活对象,那么这些对象将直接通过分配担保机制进入老年代。
老年代中采用的收集算法: