常见垃圾回收算法

概述

8195388-989c3a7e93f74e7e.png
可达性分析.png

思想:枚举根节点,做可达性分析;
根节点:类加载器、Thread、虚拟机栈的本地变量表、static成员、常量引用、本地变量表的变量等;

标记清除算法

算法分为标记和清除两个阶段,首先标记出所有需要回收的对象,在标记完成后统一回收所有;

缺点
  • 效率不高,标记和清除2个阶段料率都不高;
  • 产生碎片,碎片太多会导致提前GC;

复制算法

将可用内存按容量划分成大小相等的两块,每次只使用其中一块;当这一块的内存用完了,就将还存活的对象复制到另一块上面,然后再把已使用过的内存空间一次清理掉;

优点
  • 实现简单,运行高效;
缺点
  • 空间利用率低;

标记整理算法

标记过程仍然与“标记-清除”算法一样,但后续步骤不是直接对可回收对象进行清理,而是让所有存活的对象都向一端移动,然后直接清理掉边界以外的内存;

优点
  • 没有了内存碎片;
缺点
  • 整理内存比较耗时;

分代垃圾回收算法

  • Yong区采用复制算法;
  • Old区采用标记清除或标记整理;
对象分配
  • 对象优先在Eden分配;
  • 大对象直接进入老年代:-XX:PretenureSizeThreshold;
  • 长期存活对象进入老年代:
    -XX:MaxTenuringThreshold 如果GC后存活的年龄到这个值,进入老年代;
    -XX:+PrintTenuringDistribution 发生YongGC的时候,打印一下存活对象的年龄分布;
    -XX:TargetSurvivorRatio 如果GC后存活的比例达到这个值,计算所有存活的平均年龄,平均年龄和-XX:MaxTenuringThreshold取最小值,作为进入老年代的条件;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值