在以往的教科书中说java是采用引用计数算法来决定gc的。
简单描述下引用计数算法:给对象添加一个引用计数器。每当有一个地方引用它时,计数器值就加1;当引用失效时,计数器就减1;任何时刻计数器为0的对象就是不可能再被使用的。
但现在较新的gc采用的是可达性分析算法。这个算法的基本思路是通过一系列的称为"GC Roots"的对象作为起始点,从这些节点开始向下搜索,搜索所走过的路径被称为引用链,当一个多项到GC Roots没有任何引用链相连(用图论的话来说,就是从GC Roots到这个对象不可达)时,则证明此对象是不可用的。
这两种都跟引用有关,为了解决一些不必要对象的存留和减少内存占用。java特意对引用的概念进行了扩充。分为四种引用:
1、强引用;
2、软引用‘
3、弱引用;
4、虚引用;
如果想被回收晚点,可以重写finalize方法。在这个方法中重新建立一个对象连接即可。但这个方法只能减少一次被gc,第二次就不行了。
方法区和常量池里面的常量被gc需要满足三个条件:
1、该类所有的实例都已经被回收,也就是java堆中不存在该类的任何实现。
2、加载该类的ClassLoader已经被回收。
3、该类对应的java.lang.Class对象没有在任何地方被引用,无法在任何地方通过反射访问该类的方法。