JVM 新生代为什么要有两个 survivor(from, to) 区

先附一段对新生代中复制算法较好的理解:

首先得明白复制算法的思想:
将原有的内存空间划分成两块,每次只使用其中一块,在垃圾回收的时候,将正在使用的内存中的存活对象复制到另一块内存区域中,然后清除正使用过的内存区域,交换两个区域的角色,完成垃圾回收。

然后为什么要在新生代中使用复制算法:
因为新生代gc比较频繁、对象存活率低,用复制算法在回收时的效率会更高,也不会产生内存碎片。但复制算法的代价就是要将内存折半,为了不浪费过多的内存,就划分了两块相同大小的内存区域survivor
from和survivor to。在每次gc后就会把存活对象给复制到另一个survivor上,然后清空Eden和刚使用过的survivor。

以上引用自:https://www.zhihu.com/question/44929481/answer/98016105,上述回答解释了:

  1. 为什么新生代要在标记清除死亡对象后使用复制算法,而不是标记清除死亡对象后进行压缩整理以消除内存碎片(此处内存碎片是死亡对象之前所占用的空间)。

  2. 新生代使用复制算法存在的缺陷,由于使用了复制算法,每次只能使用 1/2 的空间,可使用的内存空间变成了 1/2。

  3. 由于存在 2. 中描述的缺陷,要想办法优化,让复制算法中可使用内存空间 > 1/2。优化办法是从 eden 区 : survivor 区 = 1 : 1,变为 eden 区 : survivor 区 = 8 : 2,这样可使用内存空间就变成了 8/10。但是这样在下一次 Young GC 后,存活对象移动到 survivor 区,我们的可使用区域只有 2/8,太小了。

  4. 继续优化 3. 中描述的问题,我们把新生代分为 eden 区 : survivor0(from) : survivor1(to) = 8 : 1 : 1,每次新生代对象在 eden 区创建,上一次 GC 存活的对象在 from 区,下次 GC 时要移动的对象是 eden 区和 from 区中存活的对象,移动至 to 区,然后 from 区和 to 区身份交换。这样我们新生代可使用的内存空间就有 9/10(eden + from) 了。

上述解决方案的演进为 “JVM 新生代为什么要有两个 survivor(from, to) 区” 的原因。

  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

JellyfishMIX

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值