- Java 11 and 12:New Features
- Mala Gupta
- 306字
- 2021-07-02 12:27:03
What is CDS?
CDS has been a commercial feature with Oracle JVM since Java 8. CDS helps in two ways—it helps to reduce the startup time of a Java application and reduces its memory footprint with multiple Java Virtual Machines (JVMs).
When you start up your JVM, it performs multiple steps to prepare the environment for execution. This includes bytecode loading, verification, linking, and initializing of core classes and interfaces. The classes and interfaces are combined into the runtime state of JVM so that they can be executed. It also includes method areas and constant pools.
These sets of core classes and interfaces don't change unless you update your JVM. So, every time you start your JVM, it performs the same steps to get the environment up for execution. Imagine you could dump the result to a file, which could be read by your JVM at startup. The subsequent startups could get the environment up and running without performing the intermediate steps of loading, verification, linking, and initialization. Welcome to CDS.
When you install JRE, CDS creates a shared archive file from a set of predefined set of classes from the system jar file. Classes are verified by the class loaders before they can be used—and this process applies to all the classes. To speed up this process, the installation process loads these classes into an internal representation and then dumps that representation to classes.jsa—a shared archive file. When JVM starts or restarts, classes.jsa is memory-mapped to save loading those classes.
When JVM's metadata is shared among multiple JVM processes, it results in a smaller memory footprint. Loading classes from a populated cache is faster than loading them from the disk; they are also partially verified. This feature is also beneficial for Java applications that start new JVM instances.
- ThinkPHP 5實(shí)戰(zhàn)
- OpenShift開發(fā)指南(原書第2版)
- OpenCV實(shí)例精解
- Vue.js快跑:構(gòu)建觸手可及的高性能Web應(yīng)用
- Raspberry Pi for Secret Agents(Third Edition)
- Java 9 Programming Blueprints
- C語言程序設(shè)計(jì)
- Getting Started with Python Data Analysis
- NGINX Cookbook
- Mastering Akka
- 從零開始學(xué)Python大數(shù)據(jù)與量化交易
- Joomla!Search Engine Optimization
- C#網(wǎng)絡(luò)編程高級(jí)篇之網(wǎng)頁游戲輔助程序設(shè)計(jì)
- 歐姆龍PLC編程指令與梯形圖快速入門
- Kotlin入門與實(shí)戰(zhàn)