- Java 11 and 12:New Features
- Mala Gupta
- 238字
- 2021-07-02 12:27:05
Driving factors
Imagine that you are a GC developer and you are supposed to know all the places where you could locate the code for GC in HotSpot. If this doesn't sound scary enough, imagine how it would feel if you didn't know how to extend it to your specific requirements. Or, imagine that you are a HotSpot developer (not a GC developer), and you can't seem to find a specific code for a GC. We are not done yet—now imagine that you must exclude a specific GC at build time. These cases are represented in the following diagram:

The preceding use cases demonstrate the major factors driving the changes to the code base—by pushing the creation of a clean GC interface.
Even though the code of the GCs was defined in their respective directories (for example, the src/hotspot/share/gc/g1 stored code for G1 GC), some code was defined outside these directories. A typical example of this is the barrier required by most of the GC. Since the barrier code was implemented in the C1 and C2 runtime interpreter, this code was defined in the directories that defined the code for C1 and C2. However, this leads to a fragmented GC code, which is hard to track and locate.
A GC interface introduces a layer of abstraction, taking the burden to track all the GC code off a developer (both GC and HotSpot).
- Spring Boot 2實戰之旅
- Mastering Ubuntu Server
- C語言實驗指導及習題解析
- Jupyter數據科學實戰
- Unity Game Development Scripting
- 焊接機器人系統操作、編程與維護
- Learning ArcGIS for Desktop
- Visual FoxPro程序設計習題集及實驗指導(第四版)
- Keras深度學習實戰
- Scratch趣味編程:陪孩子像搭積木一樣學編程
- 細說Python編程:從入門到科學計算
- 移動增值應用開發技術導論
- Fastdata Processing with Spark
- CodeIgniter Web Application Blueprints
- 大數據時代的企業升級之道(全3冊)