JVM中判断对象是否需要回收的方法

简介: JVM中判断对象是否需要回收的方法



       在堆里面存放着Java世界中几乎所有的对象实例,垃圾收集器在对堆进行回收前,第一件事情就是要确定这些对象之中哪些还“ 存活 着,哪些已经 死去 ”。

引用计数算法


       引用计数法是一种内存管理技术,它是通过对每个对象进行引用计数来判断对象是否可以被释放的。

基本思想

       每一个对象都有一个计数器,当有一个新的指针指向该对象时,该对象的计数器增加1;当有一个指针不再指向该对象时,该对象的计数器减少1。当对象的计数器为0时,说明该对象没有被任何指针引用,即该对象已经没有被使用,可以被释放。

引用计数法的优点

       实现简单、实时性高。它可以较快地释放不再使用的对象,因为只需要在对象引用数为0时立即释放该对象,不需要等待垃圾回收器运行。

引用计数法的缺点

一个常见的问题是循环引用,即两个或多个对象相互引用,导致它们的引用计数器永远不会为0,这样就会导致内存泄漏。解决循环引用问题需要引入其他的垃圾回收算法,比如标记-清除、复制和标记-整理等算法。同时,引用计数还可能会对程序的性能产生一定的影响,因为需要维护每个对象的引用计数器,这会增加程序的开销。

可达性分析算法


       可达性分析算法是现代垃圾回收器常用的算法之一。其基本思想是通过一系列扫描操作,检查每个对象与根对象之间是否存在引用链,如果不存在引用链,则说明该对象已经没有被使用,可以被释放。

       在可达性分析算法中,根对象是指一些已知的存在于内存中的对象,如全局变量、静态变量和栈中的变量等。垃圾回收器通过对根对象的扫描,检查每个根对象是否引用了其他对象,如果引用了,则对被引用的对象进行标记。然后对所有被标记的对象再进行扫描,检查它们是否引用了其他对象,如果引用了,则对被引用的对象进行标记。依此类推,直到所有可到达对象都被标记为活动对象,未被标记的对象则可以被视为垃圾对象,可以进行回收。

可达性分析算法的优点

       可达性分析算法能够精确地确定哪些对象可以被回收。同时,该算法具有较好的扩展性,可以应用于分代垃圾回收、增量垃圾回收、并行垃圾回收等多种垃圾回收方案。

可达性分析算法的缺点

       首先,该算法需要对所有对象进行扫描,因此时间复杂度较高,可能会影响程序的性能。其次,该算法无法处理循环引用的情况,即当两个或多个对象相互引用时,无法确定它们是否应该被回收。因此,可达性分析算法需要与其他垃圾回收算法配合使用,如引用计数法、标记-清除、复制和标记-整理等算法,以便实现更高效的垃圾回收。

可达性分析算法的工作流程

初始标记阶段

       在这个阶段,JVM会暂停所有的应用线程,进行一次快速的标记。这个阶段的目标是标记GC Roots直接关联的对象,速度较快。

并发标记阶段

       在这个阶段,垃圾回收器与应用线程同时运行,标记所有的可达对象。由于与应用线程并发执行,这个阶段的时间相对较长。

重新标记阶段

       在并发标记阶段完成后,为了处理在标记阶段应用线程继续运行而产生的新的引用关系,需要进行一次短暂的重新标记。这个阶段同样需要停顿应用线程。

并发清除阶段

       最后一个阶段是并发清除阶段,垃圾回收器清理掉那些不再被引用的对象,并释放它们占用的内存。

总结

       综合考虑,两者结合使用能够弥补各自的不足。引用计数法处理实时性要求高的场景,而可达性分析算法则提供更精确的回收判断。在实际应用中,选择适当的内存管理技术取决于具体的场景和需求。这种综合运用有助于充分利用它们的优势,提高系统的性能和稳定性。

相关文章
|
7天前
|
消息中间件 Java 应用服务中间件
JVM实战—2.JVM内存设置与对象分配流转
本文详细介绍了JVM内存管理的相关知识,包括:JVM内存划分原理、对象分配与流转、线上系统JVM内存设置、JVM参数优化、问题汇总。
JVM实战—2.JVM内存设置与对象分配流转
|
4月前
|
存储 算法 Java
散列表的数据结构以及对象在JVM堆中的存储过程
本文介绍了散列表的基本概念及其在JVM中的应用,详细讲解了散列表的结构、对象存储过程、Hashtable的扩容机制及与HashMap的区别。通过实例和图解,帮助读者理解散列表的工作原理和优化策略。
78 1
散列表的数据结构以及对象在JVM堆中的存储过程
|
3月前
|
存储 Java 开发者
浅析JVM方法解析、创建和链接
上一篇文章《你知道Java类是如何被加载的吗?》分析了HotSpot是如何加载Java类的,本文再来分析下Hotspot又是如何解析、创建和链接类方法的。
346 132
|
3月前
|
缓存 Java
JVM对象引用
本次课程聚焦JVM对象引用,涵盖强引用、软引用、弱引用和虚引用。强引用是最常见的引用类型,确保对象不会被垃圾回收器回收,适用于需要确保对象存活的场景;软引用在内存不足时会被优先回收,常用于缓存;弱引用的对象随时可能被回收,适合临时对象;虚引用最弱,主要用于接收对象回收通知,进行资源清理。通过合理选择引用类型,可优化内存管理,避免内存泄露。
|
5月前
|
缓存 算法 Java
JVM知识体系学习六:JVM垃圾是什么、GC常用垃圾清除算法、堆内存逻辑分区、栈上分配、对象何时进入老年代、有关老年代新生代的两个问题、常见的垃圾回收器、CMS
这篇文章详细介绍了Java虚拟机(JVM)中的垃圾回收机制,包括垃圾的定义、垃圾回收算法、堆内存的逻辑分区、对象的内存分配和回收过程,以及不同垃圾回收器的工作原理和参数设置。
227 4
JVM知识体系学习六:JVM垃圾是什么、GC常用垃圾清除算法、堆内存逻辑分区、栈上分配、对象何时进入老年代、有关老年代新生代的两个问题、常见的垃圾回收器、CMS
|
4月前
|
监控 Java Spring
JVM如何监控某个方法的入参和相应结果?
JVM如何监控某个方法的入参和相应结果?
57 0
|
5月前
|
存储 Java
JVM知识体系学习四:排序规范(happens-before原则)、对象创建过程、对象的内存中存储布局、对象的大小、对象头内容、对象如何定位、对象如何分配
这篇文章详细地介绍了Java对象的创建过程、内存布局、对象头的MarkWord、对象的定位方式以及对象的分配策略,并深入探讨了happens-before原则以确保多线程环境下的正确同步。
110 0
JVM知识体系学习四:排序规范(happens-before原则)、对象创建过程、对象的内存中存储布局、对象的大小、对象头内容、对象如何定位、对象如何分配
|
5月前
|
Java
JVM进阶调优系列(5)CMS回收器通俗演义一文讲透FullGC
本文介绍了JVM中CMS垃圾回收器对Full GC的优化,包括Stop the world的影响、Full GC触发条件、GC过程的四个阶段(初始标记、并发标记、重新标记、并发清理)及并发清理期间的Concurrent mode failure处理,并简述了GC roots的概念及其在GC中的作用。
|
9天前
|
存储 缓存 算法
JVM简介—1.Java内存区域
本文详细介绍了Java虚拟机运行时数据区的各个方面,包括其定义、类型(如程序计数器、Java虚拟机栈、本地方法栈、Java堆、方法区和直接内存)及其作用。文中还探讨了各版本内存区域的变化、直接内存的使用、从线程角度分析Java内存区域、堆与栈的区别、对象创建步骤、对象内存布局及访问定位,并通过实例说明了常见内存溢出问题的原因和表现形式。这些内容帮助开发者深入理解Java内存管理机制,优化应用程序性能并解决潜在的内存问题。
JVM简介—1.Java内存区域
|
2月前
|
存储 设计模式 监控
快速定位并优化CPU 与 JVM 内存性能瓶颈
本文介绍了 Java 应用常见的 CPU & JVM 内存热点原因及优化思路。
662 166