笔记:JVM垃圾回收机制

GC发生在JVM什么位置

GC是发生在堆里面

在这里插入图片描述

GC(分代收集算法)的分类

  • 次数频繁收集年轻区 Young区—— Minor GC
  • 次数上较少收集老年区Old区—— Full GC
  • 基本不动永久区 Perm区

GC 的算法

引用计数法

  • 对象互相之间有引用,GC就不进行垃圾回收
  • 缺点:
    • 每次对对象赋值时均要维护引用计数器,且计数器本身也有一定的消耗
    • 较难处理循环引用
  • JVM的实现一般不采用这种方式,已经淘汰

复制算法(Coping)

  • 发生在年轻代 Minor GC
  • 原理:
    • 从根基合(GC ROOT)开始,通过Tracing从From中找到存活对象,拷贝到To总
    • From、To交换身份,下次内存分配从To开始
  • 缺点:需要双倍空间
  • 优点:
    • 效率高,没有标记和清除的过程
    • 快速分配内存,没有内存碎片,可利用bump-the-pointer快速内存分配
    • 在这里插入图片描述

标记清除(Mark-Sweep)

  • 老年代一般是由标记清除或者标记清除与标记整理的混合实现
  • 标记(Mark)
    • 从根集合开始扫描,对存活的对象进行标记
      在这里插入图片描述
  • 清除(Sweep)
    • 扫描整个内存空间,收回未被标记的对象,使用free-list记录可以区域
      在这里插入图片描述
  • 优点:不需要额外空间
  • 缺点:
    • 两次扫描,耗时严重
    • 会产生内存碎片

标记压缩(Mark-Compact)

  • 发生在老年代
  • 标记(Mark):与标记-清除一样
    -在这里插入图片描述
  • 压缩(Compact)
    • 再次扫描,并往一端滑动存活对象
      在这里插入图片描述
  • 优点:没有内存碎片,可以利用bump-the-pointer
  • 缺点:需要移动对象的成本

标记清除压缩(Mark-Sweep-Compact)

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值