JVM垃圾回收机制

文章介绍了JVM中的几种垃圾标记算法,如引用计数法和可达性分析算法,以及不同的垃圾回收算法,如标记-清除、标记-整理和复制算法。在实现层面上,讨论了Parallel和CMS收集器的特点,CMS关注响应时间,而Parallel关注吞吐量。文章还涵盖了内存分配策略,包括新生代和老年代的垃圾收集。

JVM垃圾标记算法:

  • 引用计数法:当对象被引用的次数为0时,可被标记为垃圾
  • 可达性分析算法:当垃圾回收时,由根节点开始扫描,不可到达的对象节点则标记为垃圾

JVM垃圾回收算法(理论层面):

  • 标记-清除算法:将存活的对象进行标记,然后清理掉未被标记的对象。缺点是会产生大量内存碎片,可能无法分配内存给大对象。
  • 标记-整理算法:将存活的对象向一端对齐,直接清楚边界以为的内存对象。
  • 复制算法:将堆空间分为两份,每次只使用一份。垃圾回收时,将存活的对象,复制到另一份空间中。这种算法不会产生大量内存碎片,但比较耗费内存。现在大部分JVM的新生代都采用这种算法进行垃圾回收。新生代被分为一个Eden区和两个Survivor区。每次新生代垃圾回收时,将一个Eden区和一个Survivor区存活的对象复制到另一个Survivor区。Eden和Survivor区的默认比例是8:1,当另一个Survivor区不够存放时,会将多出的对象存放到老年代。
  • 分代收集理论:将堆内存分为新生代和老年代。新生代采用复制算法,老年代采用标记-清除或者标记-整理算法。

JVM垃圾回收器(实现层面):

Parallel收集器关注吞吐量,整个垃圾时间最短,吞吐量就大,吞吐量就是执行用户的CPU时间与CPU总耗时的比值。CMS关注响应时间,提高用户体验,STW时间变短。大内存使用CMS。

CMS垃圾收集流程:初始标记(STW)=》并发标记 =》重新标记(STW)=》并发清除。

内存分配和回收策略:

  • 新生代收集(Minor GC/Young GC):只是新生代的垃圾收集。
  • 老年代收集(Major GC/Old GC):只是老年代的垃圾收集。
  • 整堆收集(Full GC):收集整个 Java 堆和方法区的垃圾
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值