服务器之家

服务器之家 > 正文

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

时间:2021-06-08 15:10     来源/作者:Sam哥哥

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

概述

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

应用场景

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

jvm将heap 内存划分为新生代与老年代,又将新生代划分为eden(伊甸园) 与2块survivor space(幸存者区) ,然后在eden –>survivor space 以及from survivor space 与to survivor space 之间实行copying 算法。

不过jvm在应用coping算法时,并不是把内存按照1:1来划分的,这样太浪费内存空间了。一般的jvm都是8:1。也即是说,eden区:from区:to区域的比例是8:1:1

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

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

1、当eden区满的时候,会触发第一次young gc,把还活着的对象拷贝到survivor from区;当eden区再次触发young gc的时候,会扫描eden区和from区域,对两个区域进行垃圾回收,经过这次回收后还存活的对象,则直接复制到to区域,并将eden和from区域清空。

2、当后续eden又发生young gc的时候,会对eden和to区域进行垃圾回收,存活的对象复制到from区域,并将eden和to区域清空。

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

注意:

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

优点

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

缺点

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

总结

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

原文链接:https://blog.csdn.net/linsongbin1/article/details/51668859

相关文章

热门资讯

2020微信伤感网名听哭了 让对方看到心疼的伤感网名大全
2020微信伤感网名听哭了 让对方看到心疼的伤感网名大全 2019-12-26
yue是什么意思 网络流行语yue了是什么梗
yue是什么意思 网络流行语yue了是什么梗 2020-10-11
背刺什么意思 网络词语背刺是什么梗
背刺什么意思 网络词语背刺是什么梗 2020-05-22
苹果12mini价格表官网报价 iPhone12mini全版本价格汇总
苹果12mini价格表官网报价 iPhone12mini全版本价格汇总 2020-11-13
2021德云社封箱演出完整版 2021年德云社封箱演出在线看
2021德云社封箱演出完整版 2021年德云社封箱演出在线看 2021-03-15
返回顶部