垃圾回收算法

垃圾回收是Java体系最重要的组成部分之一,垃圾回收器的任务是识别和回收垃圾对象进行内存清理。以下是涉及算法的简单描述:

一、垃圾回收算法

1、引用计数法

思路:对于一个对象A,只要有任何一个对象引用A,则A的引用计数器就加1,当引用失效时,引用计数器就减1.只要对象A的引用计数器的值为0,则对象A就不可能再被使用。

                                        

缺点:

(1)、无法处理循环引用的情况,因此,在Java的垃圾回收器中,没有使用这种算法。

(2)、引用计算器要求在每次因引用产生和消除的时候,需要伴随一个加法操作和减法操作,对系统性能会有一定的影响。

可达对象:指通过根对象进行引用搜索,最终可以达到的对象。

不可达对象:通过根对象进行引用搜索,最终没有被引用到的对象。

2、可达性分析算法

思路:通过一系列的称为“GC Roots”的对象最为起始点,从这些节点开始向下搜索,搜索所走的路径称为引用链(Reference Chain),当一个对象到GC Roots没有任何引用链相连时,则证明此对象是不可用的。如下图:

判断条件:gc roots为起始点

可作为gc roots对象有以下几种:

(1)、虚拟机栈中引用的对象

(2)、方法区中类静态属性引用的对象

(3)、方法区中常量引用的对象

(4)、本地方法栈中JNI引用的对象

3、标记清除法

思路:标记清除算法将垃圾回收分为两个阶段:标记阶段和清除阶段。一种可行的实现是,在标记阶段,首先通过根节点,标记所有从根节点开始的可达对象。因此,未被标记的对象就是未被引用的垃圾对象。然后,在清除阶段,清除所有未被标记的对象。标记清除算法可能产生的最大问题是空间碎片。

                               

4、复制算法

思路:将原有的内存空间分为两块,每次只使用其中一块,在垃圾回收时,将正在使用的内存中的存活对象复制到未使用的内存块中,之后,清除正在使用的内存块中所有对象,交换两个内存的角色,完成垃圾回收。比较适合用于新生代,因为在新生代,垃圾对象通常会多于存活对象。

 

新生代:存放年轻对象的堆空间。年轻对象指刚刚创建的,或者经历垃圾回收次数不多的对象。

老年代:存放老年对象的堆空间。老年对象指经历过多次垃圾回收依然存活的对象。

5、标记压缩法(标记清除压缩算法)

思路:首先需要从根节点开始,对所有可达对象做一次标记。但之后,它并不只是简单地清理未标记的对象,而是将所有的存活对象压缩到内存的一端。之后,清理边界外所有的空间。避免了碎片的产生,又不需要两块相同的内存空间。

 

6、分代算法

思路:它将内存区间根据对象的特点分成几块,根据每块内存区间的特点,使用不同的回收算法,以提高垃圾回收的效率。

 

7、分区算法

思路:将整个堆空间划分成连续的不同小区间,每个小区间都独立使用,独立回收。

 

二、垃圾回收相关概念

1、可触及性

可触及的:从根节点开始,可以到达这个对象

可复活的:对象的所有引用都被释放,但是对象有可能在finalize()函数中复活。

不可触及的:对象的finalize()函数被调用,并且没有复活,那么就会进入不可触及状态,不可触及的对象不可能被复活,因为finalize()函数只会被调用一次。

2、引用和可触及性的强度

四个级别:强引用、软引用、弱引用、虚引用

强引用:是程序中一般使用的引用类型,强引用的对象是可触及的,不会被回收。类似 Object object=new Object();

而在一定条件下,软引用、弱引用、虚引用等都可以被回收。

强引用特点:

(1)、可以直接访问目标对象

(2)、对象在任何时候都不会被系统回收,虚拟机宁愿抛出OOM异常,也不会回收强引用所指对象。

(3)、可能导致内存泄露。

软引用:用来描述一些还有用但并非必需的对象,对于软引用关联着的对象,在系统将要发生内存溢出异常之前,将会把这些对象列进回收范围之中进行第二次回收。如果这次祸首还没有足够的内存才会抛出内存溢出异常。如SoftReference

弱引用:用来描述非必需对象的,但是它的强度比软引用更弱一些,被弱引用关联的对象只能生存到下一次垃圾收集发生之前。当垃圾收集器工作时,无论当前内存是否足够,都会回收掉只被弱引用关联的对象。如WeakReference

虚引用:也称幽灵引用或者幻影引用,它是最弱的一种引用关系。一个对象是否有虚引用的存在,完全不会对其生存时间构成影响,也无法通过虚引用来取得一个对象实例。为一个对象设置虚引用关联的唯一目的就是能再这个对象被收集器回收时收到一个系统通知。如PhantomReference

 

以上内容来源于 <<实战Java虚拟机_JVM故障诊断与性能优化>> 的学习笔记,喜欢的点赞,谢谢。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值