前言:万事开头难,先从基础概念讲起吧,老规矩,还是以JDK8版本主讲。
一,垃圾收集算法
复制算法:将内存分为大小相同的两块(运行区域,预留区域 ),每次分配的对象都存放在运行区域,当运行区域内存不够时,会将存活的对象复制到预留区域,然后清理垃圾对象,结束后运行区域就转变为预留区域,而预留区域就变成了运行区域(有点像survivorFrom和SurvivorTo)
标记清除算法:先做标记,再去清除。一般是标记存活的对象,然后统一回收未标记的垃圾对象。
标记整理算法:标记整理算法的标记阶段与其他算法一样,但是在整理阶段,算法将存活的对象向内存空间的一端移动,然后将存活对象边界以外的空间全部清空
二,什么样的对象才是垃圾?
在茫茫的java堆中,到处都是对象,怎么分辨这些对象是不是垃圾对象呢?因为一旦搞错对象,就会出现很严重的问题。
一般有两种方法:
引用计数法:当对象被引用时计数器加1,失去引用时计数器减1,当为0时就可以认为对象成为了垃圾对象。但是会有对象相互引用的问题,这样会导致对象永远存在被引用,所以一般不会用这种算法。
public class Test {
Object test;
public static void main(String[] args) {
Test t1 = new Test();
Test t2 = new Test();
t1.test = t2;
t2.test = t1;
}
}
可达性分析算法:GCRoot对象为根节点,然后开始向下查找引用的对象,可能找到的对象标识为非垃圾对象,其他的标记为垃圾对象。
GCRoot节点一般为线程栈的本地变量(局部变量,参数等),静态变量等
(图片引自网络,如有侵权请联系删除)
总结:Java垃圾回收机制是我一直想写的一个内容。但因为涉及的东西多,而且也比较难理解,所以本节只是粗略抛出了两个问题:垃圾收集算法和垃圾对象判断机制。阿雷其间有拜读和参考《深入理解Java虚拟机》这本书,有志同道合的朋友可以关注下,共勉。