许老撕 2021-05-20 15:52 采纳率: 100%
浏览 73
已采纳

G1收集器的S区为什么没有转换?

各位好,有个问题无法在网上找到答案,所以在这里提问一下。

按照原理,当E区占满并执行YGC后,应该把E区的对象放入S区,S区有两个,分为S1和S0,S区会在每次YGC之后用 to 和 from 标识不停设换,然后把对象放入其中一个S区,以此循环。而在实际应用中,我发现如果使用G1收集器时,E区满了之后并且执行YGC后,对象会直接进入S1区和O区,但每次YGC都只使用S1区,没有使用S0区,而且使用 jmap -heap pid 输出堆简要信息后,也只有一个S区信息,和其他收集的不一样,请问是什么原因导致使用G1收集器时S区没有轮流设换?

 

  • 写回答

3条回答 默认 最新

  • CSDN专家-三岁丫 2021-05-21 11:17
    关注

    不好意思说的有点问题,我刚才想了想 G1 的内存模型和其他的内存模型不太一样。所以并没有 S0、S1 的说法。

    https://zhuanlan.zhihu.com/p/59861022 具体可以看这篇文章。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?