- Java 11 and 12:New Features
- Mala Gupta
- 300字
- 2021-07-02 12:27:06
Understanding G1 GC logs
In this section, we will have a look at the G1 GC logs in detail.
The following features are marked in the following screenshot:
- Each heap region is of the size, 1M.
- The JVM is using G1 as its GC.
- The G1 collector starts a young collection 0.309 seconds after starting the application execution.
- The G1 collector uses multiple threads for the young collection.
- The G1 collector moves live objects from 14 Eden regions to 2 Survivor regions:

Let's examine another section of the same GC log, as follows:

The logs in the preceding screenshot are part of the same GC collection (note GC (5) in the logs). It shows logs from another young collection by the G1 GC. I've highlighted the Eden, Survivor, Old, and Humongous regions that the collector worked on. The values on the left side of the arrows show the counts of regions before the collection, and the values on the right are the counts of regions after the GC.
Let's examine the last section of the G1 log before the JVM quits with OutOfMemoryError, as follows:
- The collection uses multiple threads for the full collection.
- Full GC starts.
- Full GC includes a multiple number of steps, including marking live objects, preparing for compaction, adjusting pointers, and compacting the heap.
- As you will notice, there are no more Eden regions and Survivor regions available for allocation and compaction (0 -> 0). The Old and Humongous regions contain live objects that can't be collected. As a result, the JVM shuts down with OutOfMemoryError.
- This information logs the actual time taken by the full GC:

The bottom of the preceding screenshot includes a few final statistics, including total heap size, used heap size, region size, and more.
- JavaScript 從入門到項目實踐(超值版)
- Python高級機器學習
- PHP+MySQL網站開發項目式教程
- Mastering Apache Spark 2.x(Second Edition)
- 低代碼平臺開發實踐:基于React
- Oracle GoldenGate 12c Implementer's Guide
- Mastering Python Design Patterns
- 深入實踐Kotlin元編程
- 計算機應用技能實訓教程
- 計算機應用基礎案例教程(第二版)
- Using Yocto Project with BeagleBone Black
- 軟技能2:軟件開發者職業生涯指南
- Tkinter GUI Programming by Example
- Visual Basic 開發從入門到精通
- iOS應用逆向工程:分析與實戰