如果无法从任何活动线程或任何静态引用访问对象,则该对象将有资格进行垃圾收集或GC。
换句话说,如果一个对象的所有引用都是空的,那么它就有资格进行垃圾回收。循环依赖关系不算为引用,因此如果对象A引用对象B,对象B引用对象A,并且它们没有任何其他活动引用,那么对象A和B都有资格进行垃圾收集。
用于垃圾收集的堆代-
中创建Java对象Heap和Heap为了在Java中进行垃圾收集,将其分为三个部分或几代,它们称为年轻一代(新一代)、终身(老)一代和珀姆地区堆里的。
新一代进一步分为三个部分,即伊甸园空间、幸存者1空间和幸存者2空间。当第一次在堆中创建对象时,它将在伊甸园空间内的新一代中创建,并在随后的次要垃圾收集之后,如果一个对象幸存下来,则将其移动到幸存者1,然后在主要垃圾收集将该对象移动到老代或长辈.
烫发空间JavaHeap是JVM存储有关类和方法、字符串池和类级详细信息的元数据的地方。
有关更多信息,请参阅此处:垃圾收集
您不能强迫JVM运行垃圾收集,尽管您可以使用System.gc()或Runtime.gc()方法。
在java.lang.system中public static void gc() {
Runtime.getRuntime().gc(); }
在java.lang.Runtime中public native void gc(); // note native method
标记和扫描算法-
这是垃圾收集使用的最流行的算法之一。任何垃圾收集算法都必须执行两个基本操作。第一,它应该能够检测所有不可访问的对象,其次,它必须回收垃圾对象使用的堆空间,并使空间再次可供程序使用。
上述操作分两个阶段由Mark算法和扫描算法执行:标记相
扫描相位
在这里了解更多细节-标记和扫描算法