java的GC垃圾回收算法

关于垃圾回收算法,大家可能平时用到并不多,但是在面试的过程中很多人会问这方面的问题。其实主要也是考察大家对底层的一个了解,不需要很深入,但是希望大家可以大致了解这个过程。

常见的垃圾回收算法有CMS G1

我们按照回收的机制,那么可以展示成如下3种。

补充下:上面的GC roots我们成为  根可达算法,采用GC roots来判断,对象是否还可用,是否需要回收。

垃圾回收器:Garbage Collector 介绍 

其他垃圾回收算法

Serial: 主要应用于YGC的垃圾回收器,采用串行单线程的方式完成GC

CMS:  垃圾回收停顿时间较短,目前较常用的垃圾回收器。它通过初始标记、并发标记、重新标记、并发清除四个步骤完成

垃圾回收工作。缺点是 需要进行碎片整理。CMS采用“Mark-sweep”

G1: JDK7推出来的,JDK11已经设置为默认的垃圾回收器。可预测的停顿时间,与CMS相比具备压缩功能,能避免碎片问题。整体性能不错。G1采用“Mark-copy”

猜你喜欢

转载自blog.csdn.net/LB_Captain/article/details/115647550