当前位置: 首页 > 面试题库 >

Java GC:为什么有两个幸存者区域?

范承教
2023-03-14
问题内容

对于Sun /
Oracle的JVM,我读过GC算法将新一代划分为一个伊甸园区域和两个幸存者区域。我想知道的是,为什么有两个幸存者地区而不是一个?该算法可以在伊甸园和一个幸存者区域之间保持乒乓(目前它在两个幸存者区域之间的方式);或这种方法有什么缺点?


问题答案:

我相信JRockit的GC实现更像您建议的那样工作,只有一个eden和一个幸存者空间,但请不要在此引用我。

HotSpot
JVM的两个生存空间的原因是为了减少处理碎片的需要。新对象分配在伊甸园空间中。一切都很好。完成后,您需要一个GC,因此请杀死陈旧的对象并将活动的对象移到幸存者空间,在那里它们可以成熟一段时间,然后提升为老一代。到目前为止还不错。但是,下次当我们用完伊甸园的空间时,我们将面临一个难题。下一个GC出现并清除了伊甸园和幸存者空间中的某些空间,但是这些空间不是连续的。所以更好

  1. 尝试将幸存者从伊甸园中插入幸存空间中被GC清除的孔中吗?
  2. 向下移动幸存者空间中的所有对象以消除碎片, 然后 将幸存者移入其中?
  3. 只需说“拧紧它,我们无论如何都会移动所有东西”,然后将两个空间中的所有幸存者都复制到一个完全独立的空间(第二个幸存者空间)中,从而为您提供一个干净的伊甸园和幸存者空间在下一个GC上重复该序列?

Sun对这个问题的回答是显而易见的。



 类似资料:
  • 我正在浏览微软的Rust教程,它是关于 实现函数,以便返回对插入向量中的值的引用 这里给出了解决方案,但它与我的不同之处在于它使用了 除了返回类型之外,我的和标准解决方案之间的另一个区别是,我只是简单地返回了参数,而标准解决方案使用复杂方式)。 我想知道我的解决方案是否有任何问题,本教程采取了另一种方式? 虽然@Masklin为我的问题提供了一个很好的答案,但它有点特定于我给出的示例,但没有直接解

  • 本文向大家介绍createElement与cloneElement两者有什么区别?相关面试题,主要包含被问及createElement与cloneElement两者有什么区别?时的应答技巧和注意事项,需要的朋友参考一下 1.第一个参数不一样 React.cloneElement( element, [props], [...children] ) React.createElement( type

  • 问题内容: 我无法理解以下文本…这是否意味着空的构造函数?为什么拥有两个不同的版本很重要? https://docs.oracle.com/javase/specs/jvms/se7/html/jvms-2.html 在Java虚拟机级别,每个构造函数(第2.12节)都作为具有特殊名称的实例初始化方法出现。该名称由编译器提供。因为该名称不是有效的标识符,所以不能直接用Java编程语言编写的程序中使

  • 我们的服务器应用程序似乎在一段时间内表现正常,但过了一段时间后,生存空间将填满100%,从那时起,堆使用量增加,GC周期(次要和主要)变得越来越频繁,最终堆耗尽。 这是“jstat-gcutil”的一部分 我的问题是这种应用程序行为背后的主要原因是什么?是太小的年轻空间或堆,其他一些JVM参数,还是只是一个普通的旧内存泄漏? 解决这个问题的最佳策略是什么,GC调优还是应用程序重构? JDK 1.6

  • 尝试查找这个,但是我遇到的所有问题/答案都谈到了拥有2个幸存者空间的目的。我想了解拥有幸存者空间的一般目的。将物体从伊甸园移动到幸存者有什么好处?

  • 你能回答我一个关于JVM垃圾收集过程的问题吗? 为什么堆被分为伊甸园、幸存者空间和老一代? 当一个年轻的疏散被处理时,通过从根开始的引用访问对象,以找出无法到达的对象。可到达的对象标记为“活动”,不可到达的对象不标记,将被删除。 因此,所有对象都会被考虑,包括旧一代中分配的对象也会被访问并标记是否可以访问。 据我所知,同时回收年轻一代和老一代是非常困难的,因为这两代人位于内存中不同的连续部分。 但