java垃圾回收原理:
gc原理:
垃圾检测:对象不再被任何途径使用
- 给对象添加一个引用计数器,每当有一个地方引用它时,计数器+1;当引用失效时,计数器-1;任何时刻计算器值为0的对象即为不再被使用的对象。
但是Java虚拟机没有使用这种方式,因为它无法解决循环引用的问题。事实上,当程序中存在循环引用的时候,JVM依然有很好的收集效果。所以JVM并没有采用这种方法
2,可达性分析
引用链:基本思想就是通过一系列的称为”GC ROOTs”(set集合)的对象作为起始点,从这些节点开始向下搜索,搜索过的路径称为引用链。
当一个对象没有任何引用链相连的时候,则证明对象是不可用的。
在Java中,可作为GCROOT的对象包括以下几种:
@虚拟机栈中引用的对象
@方法区中类静态属性引用的对象
@方法区中常量引用的对象
@本地方法栈中引用的对象
java1.2之后的引用规则:
强引用:代码中普遍存在的 如“Objectobject=new Object()“这种形式,这类称为强引用。只要强引用还在,垃圾收集器永远不会进行收集
软引用:用来描述一些还有用的非必需的对象。对于这一类对象,只有在系统发生内存溢出前引发的回收,才会把这些类对象纳入到回收范围之内。如果这些回收还没有足够的内存,则会发生内存溢出。
弱引用:描述非必须对象,强度比软引用还要弱一点。这一些对象只能生存到下一次回收前,只要垃圾收集器工作,他们就会被回收
虚引用:一个对象的虚引用几乎没有意义,也不能通过虚引用去获得一个对象。为对象设置虚引用的唯一目的就是在这个对象被回收的时候收到一个系统通知。
3,两次标记判定死亡
3.1 对象经过可达性分析以后,还不能立即判定为死亡对象,要宣告一个对象死亡,至少需要经过两次标记过程。
对这个对象是否有必要执行finalize方法
3.2自救:对象如果在finalize方法中把自己与某个引用链关联起来,就可以进行“自救”,即把自己移除出“即将回收”的集合中。如果这个对象还没有逃脱,那么它将被回收了。
垃圾回收:
新生代回收算法:复制算法
内存按容量划分为相等两个区域,将活着的复制到另一个区域
而是将内存分为一块较大的Eden区,和两个较小的Survivor空间,每次使用Eden和其中的一块survivor空间。当回收时,将Eden和survior空间上还存活的对象放入另一块survivor空间,清理掉Eden和刚刚使用的survivor区域。HotSpot区域默认的 Eden与survivor的大小比为8:1,也就是新生代每次占用90%的新生代空间进行内存分配,只有10%被浪费掉。当回收复制时,survivor空间不足时,就要依赖老年代进行分配担保。
老年代中,不宜采用复制算法。根据老年代的特点,提出了“标记-整理”算法
分代收集
目前虚拟机都采用分代收集的算法,把java堆分为新生代和老年代。新生代中对象消亡的比较快,采用复制算法,老年代中对象存活率较高,采用标记-清除或标记整理进行回收
http://www.importnew.com/23035.html
jvm垃圾收集器系列教程
https://blog.csdn.net/u010723709/article/details/47355499
JVM垃圾回收与性能调优总结
https://blog.csdn.net/u013851082/article/details/53516777
ConcurrentHashMap详解
https://blog.csdn.net/u010723709/article/details/48007881
网友评论