教育行業(yè)A股IPO第一股(股票代碼 003032)

全國咨詢/投訴熱線:400-618-4000

ParNew垃圾收集器(Serial+多線程)是干什么用的?

更新時(shí)間:2023年08月07日09時(shí)43分 來源:傳智教育 瀏覽次數(shù):

好口碑IT培訓(xùn)

  在Java中,ParNew垃圾收集器是一種垃圾收集算法,它是Serial垃圾收集器的多線程版本。它主要用于新生代(Young Generation)的垃圾收集。新生代是Java堆內(nèi)存的一部分,主要用于存放新創(chuàng)建的對象。

  ParNew垃圾收集器的設(shè)計(jì)目標(biāo)是在多核CPU上并行地進(jìn)行垃圾收集,以提高垃圾收集的效率和吞吐量。相比于單線程的Serial垃圾收集器,ParNew垃圾收集器可以充分利用多核處理器的優(yōu)勢,在一定程度上減少垃圾收集的停頓時(shí)間,從而提高應(yīng)用程序的響應(yīng)性能。

  ParNew垃圾收集器的工作流程如下:

  1.初始標(biāo)記(Initial Mark)

  停止應(yīng)用程序的線程,僅僅標(biāo)記出在新生代中直接引用的對象,這個(gè)階段是與應(yīng)用程序并發(fā)執(zhí)行的。

  2.并發(fā)標(biāo)記(Concurrent Mark)

  在此階段,垃圾收集器會與應(yīng)用程序并發(fā)地執(zhí)行,標(biāo)記所有從根對象可達(dá)的對象。這個(gè)階段的并發(fā)執(zhí)行能夠減少垃圾收集的停頓時(shí)間。

  3.重新標(biāo)記(Remark)

  停止應(yīng)用程序的線程,重新標(biāo)記在并發(fā)標(biāo)記階段有可能被修改的對象,以確保標(biāo)記的準(zhǔn)確性。

ParNew垃圾收集器

  4.并發(fā)清除(Concurrent Sweep)

  在此階段,垃圾收集器會與應(yīng)用程序并發(fā)地執(zhí)行,清除被標(biāo)記為垃圾的對象,并釋放它們占用的內(nèi)存空間。

  5.并發(fā)重置(Concurrent Reset)

  在清除完成后,垃圾收集器會與應(yīng)用程序并發(fā)地執(zhí)行,對垃圾收集器的數(shù)據(jù)結(jié)構(gòu)進(jìn)行重置,為下一次垃圾收集做準(zhǔn)備。

  值得注意的是,并發(fā)標(biāo)記、并發(fā)清除和并發(fā)重置階段的執(zhí)行是與應(yīng)用程序并行進(jìn)行的,這是ParNew垃圾收集器的一個(gè)顯著特點(diǎn),可以充分利用多核處理器,提高垃圾收集的效率和整體吞吐量。

  ParNew垃圾收集器通常與CMS(Concurrent Mark-Sweep)垃圾收集器搭配使用。CMS垃圾收集器主要負(fù)責(zé)老年代(Old Generation)的收集,而ParNew垃圾收集器則負(fù)責(zé)新生代的收集。這樣的組合可以在一定程度上減少應(yīng)用程序的停頓時(shí)間,提高系統(tǒng)的響應(yīng)性能。然而,值得注意的是,CMS垃圾收集器在進(jìn)行垃圾收集時(shí)可能會產(chǎn)生碎片,如果碎片過多,可能會影響應(yīng)用程序的性能。因此,這種組合并不適用于所有場景,需要根據(jù)具體應(yīng)用程序的特點(diǎn)進(jìn)行調(diào)優(yōu)和選擇合適的垃圾收集器組合。

0 分享到:
和我們在線交談!