JVM垃圾收集


 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
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值