Java垃圾回收之复制算法详解

  

之前的Java垃圾回收之标记清除算法详解会导致内存碎片。下文的介绍的应对算法可以解决内存碎片问题。

  

<强>概述

  

如果jvm使用了应对算法,一开始就会将可用内存分为两块,从域和域,每次只是使用域、域,则空闲着。当从域内存不够了,开始执行GC操作,这个时候,会把从域存活的对象拷贝到域,然后直接把从域进行内存清理。

  

<强>应用场景

  

应对算法一般是使用在新生代中,因为新生代中的对象一般都是朝生夕死的,存活对象的数量并不多,这样使用应对算法进行拷贝时效率比较高。

  

jvm将堆内存划分为新生代与老年代,又将新生代划分为伊甸园(伊甸园)与2块幸存者空间(幸存者区),然后在伊甸园→幸存者空间以及从幸存者空间与幸存者空间之间实行复制算法。

  

不过jvm在应用应对算法时,并不是把内存按照1:1来划分的,这样太浪费内存空间了。一般的jvm都是8:1。也即是说,伊甸园区:区:区域的比例是<代码> 8:1:1

  

始终有90%的空间是可以用来创建对象的,而剩下的10%用来存放回收后存活的对象。

  

癑ava垃圾回收之复制算法详解"

  

1,当伊甸园区满的时候,会触发第一次年轻的gc,把还活着的对象拷贝到幸存者从区;当伊甸园区再次触发年轻gc的时候,会扫描伊甸园区和从区域,对两个区域进行垃圾回收,经过这次回收后还存活的对象,则直接复制到到区域,并将伊甸园和从区域清空。
  

  

2,当后续伊甸又发生年轻gc的时候,会对伊甸园和到区域进行垃圾回收、存活的对象复制到从区域,并将伊甸园和到区域清空。
  

  

3,可见部分对象会在从和区域中复制来复制去,如此交换15次(由JVM参数MaxTenuringThreshold决定,这个参数默认是15),最终如果还是存活,就存入到老年代

  

注意:   

      <李>万一存活对象数量比较多,那么,域的内存可能不够存放,这个时候会借助老年代的空间。   
  

<>强优点

  

在存活对象不多的情况下,性能高,能解决内存碎片和Java垃圾回收之标记清除算法详解中导致的引用更新问题。

  

<强>缺点

  
      <李>会造成一部分的内存浪费。不过可以根据实际情况,将内存块大小比例适当调整,李   <李>如果存活对象的数量比较大,应对的性能会变得很差。   
  

<强>总结

  

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对的支持。如果你想了解更多相关内容请查看下面相关链接

Java垃圾回收之复制算法详解