Java虚拟机(jdk1.8)学习笔记(垃圾收集算法)

分代收集

弱分代:绝大多数对象都是朝生夕灭的。

强分代:熬过越多次垃圾收集过程的对象就越难以消亡。

在Java中,垃圾收集器将Java堆划分出不同的区域,将对象根据不同的年龄分配到不同区域。根据不同的区域,划分不同的回收类型。针对不同的区域及存储对象存储特征,推出不同的垃圾收集算法,“标记清除算法”、“标记复制算法”、“标记整理算法”。

部分收集(Partial GC):只对Java堆中的部分区域进行垃圾回收,部分收集又划分为新生代收集、老年代收集、混合收集

  • 新生代收集(Minor GC/Young GC):只对新生代区域进行垃圾回收。
  • 老年代收集(Major GC/Old GC):只对老年代进行垃圾回收。
  • 混合收集(Mixed GC):对整个新生代及部分老年代进行垃圾回收。目前只有G1收集器会有这种行为

整堆收集(Full GC):对整个Java堆和方法区的进行垃圾回收 

 标记清除算法

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

该算法效率会随着需要被回收对象的数量增加而降低;并且会存在空间碎片化问题,即:标记清除后会产生不连续的内存碎片。

标记复制算法

该算法将内存划分为大小相等的两块,每次只使用其中一块。比如现在分为a、b两块区域,a区为保留区域,b区为使用区域,当b区区域空间不足时,将存活的对象从b区复制到a区,再将b区对象清除。

该算法避免空间碎片化问题,并且将对象重新分配内存时只需要移动指针,实现简单高效。其缺陷也显而易见,因为需要保留一块空间,需要使用的空间是其他算法的两倍。

标记整理算法

该算法标记与标记清除算法一样,但是后续并不是直接对标记的对象进行回收,而是让所有存活的对象都像一边移动,然后清理掉边界以外的内存。

 下一章对HotSpot算法进行介绍分析,谢谢观看。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小武的Java笔记

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值