堆中几乎存放这Java世界中所有的对象实例,垃圾收集器在对堆进行回收前,第一件事情就是要确定这些对象有哪些还"存活"着,哪些已经"死去"(即不可能再被任何途径使用的对象)。
1,引用计数算法
给对象添加一个引用计数器,每当有一个地方引用它时,计数器就加1;当引用失效时,计数器就减1;任何时刻计数器都为0的对象就是不可能再被使用的。客观地讲,引用计数法的实现简单,判定效率也高,但Java中没有选用其来管理内存,其中最主要的原因是它很难解决对象之间的相互循环引用的问题。
例子:
如下代码,对象objA和objB都有字段instance,赋值令objA.instance=objB 及objB.instance=objA,除此之外,这量个对象再无任何引用,但是他们之间因为相互引用着对方,导致它们的引用计数都不为0,于是引用计数法无法通知GC收集器回收它们。
public class RefGC{ public Object instance=null; private static final int _1MB=1024*1024; //给变量赋予一定内存, private byte[] bigSize=new byte[2 * _1MB]; public static void tesetGC(){ RefGC objA=new RefGC(); RefGC objB=new RefGC(); objA.instance=objB; objB.instance=objA; objA=null objB=null; System.gc(); } }
2,跟搜索算法
在主流的商用程序语言中,都是使用根搜索算法(GC Root Tracing)判定对象是否存活的。这个算法的基本思路是通过一系列的名为"GC Roots"的对象作为起点,从这些结点开始向下搜索,搜索所走过的路径称为引用链,当一个对象到GC roots 没有任何引用链相连时,则证明次对象是不可用的。
在Java 语言里,可作为GC Roots的对象包括 :
1)虚拟机栈(栈桢中的本地变量表)中引用的对象。
2)方法区中的类静态属性引用的对象
3)方法区中的常量引用的对象
4)本地方法栈中JNI(Native方法)的引用对象。
相关推荐
本文将详细讲解JVM如何判断对象已死的两种主要算法:引用计数算法和可达性分析算法,以及JDK 1.2之后引入的不同类型的引用。 首先,我们来看引用计数算法。这是一种简单的对象存活判断方法,为每个对象添加一个引用...
【JVM的GC如何判断对象是否死亡】 在Java的虚拟机(JVM)中,垃圾收集(GC)机制是自动管理内存的关键部分。它负责识别并清除那些不再使用的对象,以便释放内存资源。理解GC如何判断对象是否死亡是优化Java应用程序...
•Object类提供的equals方法判断两个对象相等的标准与==完全相同。因此开发者通常需要重写equals方法。 类成员 •在java类里只能包含Field,方法,构造器,初始化块,内部类(接口、枚举)等5种成员。 用...
但随着科技的发展,越来越多的生命维持设备,如呼吸机,可以维持心脏跳动和血液循环,甚至呼吸功能,这使得人们在面对心跳尚存但脑功能已丧失的情况下,对于何谓“真正”的死亡产生了疑问。因此,从科学角度对死亡的...
假死是指人体的循环、呼吸和脑的功能活动高度抑制,生命活动极微弱,用一般临床检查方法检查不出生命体征,外表看来好像人已死亡,而实际上还活着的一种状态。假死的诊断包括线扎指头、微弱呼吸检查、ECG 检查、X 线...
判断对象是否已死主要依据两个标准: 1. **引用计数法**:记录对象被引用的数量,当数量为0时则认为对象可被回收。但这种方法无法解决对象相互循环引用的问题。 2. **可达性分析算法**:从一组根对象出发,如果一个...
这个压缩包文件"练习题(含答案)_c++oj答案_c++类oj习题_"似乎包含了一系列关于C++类与对象的在线判断题(Online Judge, OJ)解答,这对于学习者来说是一个宝贵的资源,可以帮助他们检验和提升在类和对象方面的理解...
判断对象是否可被回收通常采用可达性分析算法,如果从GC Roots出发,没有任何引用链可以到达某个对象,则认为该对象已经“死掉”,可以被回收。GC Roots一般包括以下几种: - 正在执行的方法栈中的局部变量。 - ...
这是目前主流的判断对象是否存活的方式。通过从一组称为GC Roots的对象开始,沿着引用链向下搜索。如果一个对象不能从GC Roots到达,那么它被认为是不可达的,可以被回收。可达性分析可以有效解决循环引用的问题,但...
可以,现在的虚拟机基本都是通过可达性分析算法来判断对象是否存活的,而不是通过简单的引用计数法来判断对象是否存活。可达性分析算法使用一系列的“GC Roots”对象(虚拟机栈中引用的对象、静态属性引用对象)作为...
- **可达性分析算法**:从一组根节点开始向下搜索,若对象不可达,则认为该对象已死。常见的根节点包括:静态变量中的引用、方法调用栈中的局部变量等。 **3.3 几种垃圾回收机制** - **标记-清除收集器**:先标记...
- 区分生前伤与死后伤:判断伤痕是在生前还是死后形成的。 - 判断致伤物:与活体鉴定相同,确认造成死亡的物体。 - 受伤时间:推断伤害发生的时间。 - 个人身份识别:通过身体特征确认死者身份。 尸体鉴定的...
* 判断是否能成活4或者是双死4或者是死4活3,如果是机器方的话给予10000分,如果是人方的话给予-10000分。 * 判断是否已成双活3,如果是机器方的话给予5000分,如果是人方的话给予-5000分。 * 判断是否成死3活3,...
它主要通过两种算法来判断对象是否死亡: 1. **引用计数算法**:简单但无法处理循环引用问题。 2. **可达性分析算法**:从GC Roots开始遍历引用链,无法到达的对象视为可回收。 垃圾收集器还分为不同类别,如: -...
- **可达性分析算法**:以GC Roots对象为起点,遍历引用链,找不到引用的对象被视为不可达,进而判断为可回收。 6. **垃圾收集器**: - **CMS(Concurrent Mark Sweep)收集器**:采用Mark-Sweep算法,可能导致...
* 判断是否能成活 4 或者是双死 4 或者是死 4,如果是机器方的话给予 10000 分,如果是人方的话给予-10000 分; * 判断是否已成双活 3,如果是机器方的话给予 5000 分,如果是人方的话给予-5000 分; * 判断是否成...
答案是,可以,现在的虚拟机基本都是通过可达性分析算法来判断对象是否存活的,而不是通过简单的引用计数法来判断对象是否存活。可达性分析算法使用一系列的“GC Roots”对象(虚拟机栈中引用的对象、静态属性引用...
当这一块的内存用完了,就将还存活着的对象复制到另一块上面,然后再把已使用过的内存空间一次清理掉。 - **标记-整理算法 (Mark-Compact)**:先标记待删除的对象,然后将存活的对象都向一端移动,随后清理掉端边界...
- **判断对象是否已死**:引用计数法和可达性分析算法(GCRoots)。 - **垃圾收集算法**:标记-清除、复制、标记-整理和分代收集算法。 - **垃圾收集器**:新生代有Serial、ParNew和Parallel Scavenge,老年代有...
2. (k) 杀死、未定义、释放:对象不再需要或其状态被改变,如赋新值或文件关闭。 3. (u) 使用:对象参与计算(c)或作为条件判断的一部分(p)。 以以下示例程序为例: ```c 1. read (x, y); 2. z = x + 2; 3. if (z ) ...