JVM垃圾收集

来源:互联网 发布:万户网络 广州公司 编辑:程序博客网 时间:2024/06/07 01:23


 1.  java GC的主流实现中,都是通过可达性分析(Reachability Analysis)来判断对象是否存活的。这个算法的基本思路就是通过一系列称为“GC Root”的对象作为起始点,从这些节点开始向下搜索,搜索走过的路径称为引用链(Reference Chain),当没有引用链可达,则证明此对象是不可用的。

2.在java语言中,可作为GC Roots的对象包括:

                  虚拟机栈中引用的对象

                  方法区中类静态属性引用的对象

                  方法区中常亮引用的对象

                  本地方法栈中JNI引用的对象         

3.java中的引用定义:

          强引用(strong reference):     类似于Object obj = new Object();只有引用存在,永远不会被回收

          软引用(SoftReference)   :       系统在将要发生内存溢出之前,回将这些对象回收

         弱应用(WeakRederence):      强度弱于软引用   ,只能生存到下一次垃圾搜集发生之前

         虚引用(PhanttomReference) :为一个对象设置虚引用的唯一目的就是在这个对象被回收时收到一个系统通知


4.垃圾收集的几种算法

        标记-清楚算法:首先标记出所有需要回收的对象,标记完成后统一回收。这是基础的回收算法,存在的问题(1:标记和清除的过程效率都不高;2:标记清除会产生大量不连续的内存碎片,空间碎片太多会导致分配交大对象时,无法找到足够的连续内存而提前触发亿垃圾收集动作。)

      复制算法:将内存分为较大的Eden空间和两个较小的Survivor空间(8:1)。每次使用一块Survivor空间和Eden空间,当回收时将Eden和Survivor还存活的对象一次性复制到Survivor空间,最后清理掉刚才用过的空间。

     标记-整理算法:标记-清除算法,将存活的对象向一端移动,再清除垃圾

   分代收集:当前商业虚拟机采用的算法。根据对象存活周期不同将内存划分为几代。一般是划分为新生代和老年代。新生代采用复制算法,老年代采用标记-清除或标记整理



                



0 0
原创粉丝点击