十种GC收集器及原理(3)—ParNew

ParNew是Java中的新生代并行垃圾收集器,使用复制算法,支持多线程。它能与CMS配合工作,但不能与Parallel Old搭配。三色标记法用于标记内存中的对象,确保无黑色对象引用白色对象,实现即时垃圾收集。ParNew可通过-XX:UseParNewGC选项启用,但在JVM 10及以上版本中已被移除。
摘要由CSDN通过智能技术生成

ParNew是用于新生代的并行多线程垃圾收集器,采用“复制”算法,与"Parallel Scavenge"使用的算法相同。它与“ Parallel Scavenge”的不同之处在于,它具有使其可以在CMS中使用的增强功能。例如,“ ParNew”执行所需的同步,以便它可以在CMS的并发阶段运行。

                                                                   图3-1:并行多线程垃圾收集过程示意图

从上图可以看出,其在STW阶段运行的GC是多线程的,这与Serial收集器的单线程形成鲜明对比。

复制算法

复制算法也是包含“标记”阶段的,所以我们叫它“标记-复制”算法更为准确。“标记-复制”算法与“标记-整理”算法非常相似,因为它们也可以重新放置所有活动对象。重要的区别是,重定位的目标是一个不同的内存区域,作为被标记为活动对象的新

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
ParNew GCJVM中的一种垃圾回收器,它是基于并行垃圾回收算法的,主要用于新生代的垃圾回收。ParNew GC在垃圾回收时使用多个线程并行地进行垃圾回收,以达到快速回收内存的目的。 ParNew GC与Serial GC的主要区别是:ParNew GC是使用多线程并行处理的,而Serial GC是单线程处理的。在垃圾回收时,ParNew GC会将堆内存分成多个区域,然后使用多个线程并行地进行垃圾回收。这样能够有效地减少垃圾回收的时间,提高应用程序的吞吐量。 ParNew GC的垃圾回收过程分为以下几个阶段: 1. 初始标记阶段(Initial Mark):在这个阶段中,ParNew GC会暂停应用程序,然后标记出所有根对象以及所有直接引用的对象。 2. 并发标记阶段(Concurrent Mark):在这个阶段中,ParNew GC会使用多个线程并发地标记所有存活的对象。这个阶段与应用程序并发执行,所以不会造成应用程序的停顿。 3. 重新标记阶段(Remark):在这个阶段中,ParNew GC会再次暂停应用程序,然后标记出在并发标记阶段中被引用的对象。 4. 并发清理阶段(Concurrent Cleanup):在这个阶段中,ParNew GC会使用多个线程并发地清理无用的对象。这个阶段与应用程序并发执行,所以不会造成应用程序的停顿。 ParNew GC的优点是速度快,因为它使用多线程并行处理。另外,它的停顿时间相对较短,对于对响应时间有要求的应用程序来说,ParNew GC是一个不错的选择。但是,ParNew GC也有一些缺点,比如它需要更多的内存来存储垃圾回收信息,而且需要更多的CPU时间来进行垃圾回收。另外,ParNew GC只能用于新生代的垃圾回收,不能用于老年代的垃圾回收。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值