一、JVM体系结构概览 


JVM内存结构和GC垃圾回收算法

Java8以后的JVM 

 JVM内存结构和GC垃圾回收算法

GC的作用域

JVM内存结构和GC垃圾回收算法
二、常见的垃圾回收算法


(1)引用计数算法(Reference-Counting) (JVM的实现一般不采用这种方式)

JVM内存结构和GC垃圾回收算法
       引用计数算法缺点:

              每次对对象赋值时均要维护引用计数器,且计数器本身也有一定的消耗;

              较难处理循环引用。

(2)复制算法(Copying)
       Java堆从GC角度还可以细分为:新生代(Eden区、Survivor From区和Survivor To区)和老年代

       JVM内存结构和GC垃圾回收算法

1)Eden、Survivor From 复制到 Survivor To,年龄+1

首先,当Eden区满的时候,会触发第一次GC,把还活着的对象拷贝到Survivor From区,当Eden区再次触发GC的时候,会扫描Eden区和Survivor From区,对这两个区进行垃圾回收,经过这次回收后还存活的对象,则直接复制到Survivor To区(如果有对象年龄达到了老年的标准,直接复制到老年区),同时把这些对象的年龄+1。

2)清空Eden区和Survivor From区

然后,清空Eden区和Survivor From区中的对象,也即复制之后有交换,谁空谁为To。

3)Survivor From区和Survivor To区互换

最后,Survivor From区和Survivor To区互换,原Survivor To区成为下一次GC时的Survivor From区,部分对象会在From和To区复制来复制去,如此交换15次(由JVM参数MaxTenuringThreshold决定,这个参数默认是15),最终如果还存活,就存入老年代。

(3)标记清除算法(Mark-Sweep)
       算法分成标记和清除两个阶段,先标记出要回收的对象,然后统一进行回收。

JVM内存结构和GC垃圾回收算法

缺点:产生内存碎片

(4)标记整理算法(Mark-Compack)

JVM内存结构和GC垃圾回收算法
缺点:耗时

优点:没有内存碎片的产生;节省内存空间;

 

相关文章: