JVM的垃圾回收算法
Posted liuwd
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JVM的垃圾回收算法相关的知识,希望对你有一定的参考价值。
待完善...
1、引用计数算法
对象被引用,引用计数器加1。
当一个对象实例被垃圾收集时,它引用的任何对象实例的引用计数器减1
优缺点
优点:引用计数收集器可以很快的执行,交织在程序运行中。对程序需要不被长时间打断的实时环境比较有利。
缺点:无法检测出循环引用。如父对象有一个对子对象的引用,子对象反过来引用父对象。这样,他们的引用计数永远不可能为0。
1 public class Abc_test { 2 3 public static void main(String[] args) { 4 5 MyObject object1=new MyObject(); 6 MyObject object2=new MyObject(); 7 8 object1.object=object2; 9 object2.object=object1; 10 11 object1=null; 12 object2=null; 14 } 15 16 } 17 18 class MyObject{ 19 20 MyObject object; 21 22 }
这段代码是用来验证引用计数算法不能检测出循环引用。最后面两句将object1
和object2
赋值为null
,
也就是说object1
和object2
指向的对象已经不可能再被访问,但是由于它们互相引用对方,导致它们的引用计数器都不为0,那么垃圾收集器就永远不会回收它们。
以上是关于JVM的垃圾回收算法的主要内容,如果未能解决你的问题,请参考以下文章