1. 程式人生 > >JVM系列第10講:垃圾回收的幾種型別

JVM系列第10講:垃圾回收的幾種型別

我們經常會聽到許多垃圾回收的術語,例如:Minor GC、Major GC、Young GC、Old GC、Full GC、Stop-The-World 等。但這些 GC 術語到底指的是什麼,它們之間的區別到底是什麼?今天我們就來詳細說說。

Minor GC

從年輕代空間回收記憶體被稱為 Minor GC,有時候也稱之為 Young GC。對於 Minor GC,你需要知道的一些點:

  • 當 JVM 無法為一個新的物件分配空間時會觸發 Minor GC,比如當 Eden 區滿了。所以 Eden 區越小,越頻繁執行 Minor GC。
  • 當年輕代中的 Eden 區分配滿的時候,年輕代中的部分物件會晉升到老年代,所以 Minor GC 後老年代的佔用量通常會有所升高。
  • 質疑常規的認知,所有的 Minor GC 都會觸發 Stop-The-World,停止應用程式的執行緒。對於大部分應用程式,停頓導致的延遲都是可以忽略不計的,因為大部分 Eden 區中的物件都能被認為是垃圾,永遠也不會被複制到 Survivor 區或者老年代空間。如果情況相反,即 Eden 區大部分新生物件不符合 GC 條件(即他們不被垃圾回收器收集),那麼 Minor GC 執行時暫停的時間將會長很多(因為他們要JVM要將他們複製到 Survivor 區或老年代)。

Major GC

從老年代空間回收記憶體被稱為 Major GC,有時候也稱之為 Old GC。

許多 Major GC 是由 Minor GC 觸發的,所以很多情況下將這兩種 GC 分離是不太可能的。當進行 Minor GC 時,如果年輕代空間不夠,那麼就會觸發 Major GC 將存活較久的物件移動到老年代中,從而騰出更多的年輕代空間。

Full GC

Full GC 是清理整個堆空間 —— 包括年輕代、老年代和永久代(如果有的話)。因此 Full GC 可以說是 Minor GC 和 Major GC 的結合。

當準備要觸發一次 Minor GC 時,如果發現年輕代的剩餘空間比以往晉升的空間小,則不會觸發 Minor GC 而是轉為觸發 Full GC。因為JVM此時認為:之前這麼大空間的時候已經發生物件晉升了,那現在剩餘空間更小了,那麼很大概率上也會發生物件晉升。既然如此,那麼我就直接幫你把事情給做了吧,直接來一次 Full GC,整理一下老年代和年輕代的空間。

另外,即在永久代分配空間但已經沒有足夠空間時,也會觸發 Full GC。

Stop-The-World

Stop-The-World,中文一般翻譯為全世界暫停,是指在進行垃圾回收時因為標記或清理的需要,必須讓所有執行任務的執行緒停止執行任務,從而讓垃圾回收執行緒回收垃圾的時間間隔。

在 Stop-The-World 這段時間裡,所有非垃圾回收執行緒都無法工作,都暫停下來。只有等到垃圾回收執行緒工作完成才可以繼續工作。可以看出,Stop-The-World 時間的長短將關係到應用程式的響應時間,因此在 GC 過程中,Stop-The-World 的時間是一個非常重要的指標。

參考資料

JVM系列目錄


如果只是看,其實無法真正學會知識的。為了幫助大家更好地學習,我建了一個虛擬機器群,專門討論學習 Java 虛擬機器方面的內容,每週針對我所發文章進行討論答疑。如果你有興趣,關注「Java技術精選」公眾號,通過右下角選單「入群交流」加我好友,小助手會拉你入群。