The Java module system (Project Jigsaw) was introduced in Java 9, aiming to solve the problems of poor encapsulation, confusion in dependency, and JDK bloated caused by the classpath mechanism. 1. It defines module names, dependencies, export packages and services through module-info.java file to achieve strong encapsulation and reliable configuration; 2. java.base is the basis of all modules, and internal packages such as jdk.internal.* are not accessible by default; 3. Developers can use jlink to create a streamlined runtime that contains only required modules, reducing the deployment volume; 4. Modularity improves security, maintainability and dependency clarity, but there are challenges such as limited reflections and split package conflicts in migration old projects; 5. Despite the learning curve and compatibility issues, modern Java development should give priority to modular design, combined with jlink deployment, and avoid using --add-opens or --illegal-access in production environments to ensure system robustness and security. This system has profoundly influenced the operation of Java applications and has become a necessary basis for building scalable, safe and efficient systems.
Java's module system, better known as Project Jigsaw , was a long-awaited addition to the Java platform that fundamentally changed how Java applications are structured, especially starting with Java 9 . Its evolution was driven by the need to scale the JDK and large applications in a more maintained, secure, and performant way. Here's a breakdown of its journey, purpose, and impact.

Why Was Project Jigsaw Needed?
Before Java 9, Java relied on the classpath mechanism to locate and load classes at runtime. While simple, this model had several drawbacks:
- No encapsulation at the package level : All public classes were accessible, even if they weren't meant for external use (eg, internal JDK APIs like
sun.misc.Unsafe
). - "JAR Hell" : Conflicts from duplicate class names across JARs, uncle dependencies, and circular dependencies were common.
- Monolithic JDK : The entire JDK was bundled together—even if an app used only a small part, the whole runtime had to be shipped.
- Poor scalability : Large applications became harder to maintain due to uncle dependency graphs and lack of structure.
Project Jigsaw aimed to solve these by introducing a module system —a way to group packages into named, self-describing modules with explicit dependencies.

Key Components of the Java Module System
The module system introduced several core concepts:
- Module : A named collection of packages with a
module-info.java
file that declares:- The module's name
- Which packages it exports (makes publicly available)
- Which other modules it requires
- Services it uses or provide
// Example: module-info.java module com.example.myapp { java.base; java.logging; exports com.example.myapp.api; }
- java.base module : The foundational module. Every module implicitly depends on it.
- Strong encapsulation : Only exported packages are accessible. Internal packages (eg,
jdk.internal.*
) are now truly hidden. - Reliable configuration : The JVM validates the entire module graph at startup, detecting missing or conflicting modules early.
Evolution and Adoption Timeline
Version | Milestone |
---|---|
Java 7 (2011) | Project Jigsaw started, initially planned for Java 7 but deferred. |
Java 8 (2014) | Delayed again—focus shifted to lambdas and streams. |
Java 9 (2017) | Module system officially launched . JDK itself moduleized into ~90 modules. |
Java 11 (2018–present) | Modules matured. Tools like jlink allows creating custom runtime images. Spring, Jakarta EE, and other frameworks adapted. |
Java 16 | Strong encapsulation enforced by default (use --illegal-access=deny to block reflection on internal APIs). |
Practical Benefits for Developers
1. Smaller Runtime Images with jlink
You can now build a minimum JRE containing only the modules your app needs:

jlink --module-path $JAVA_HOME/jmods:myapp.jar \ --add-modules com.example.myapp \ --output myruntime
This reduces container sizes and attack surface—ideal for microservices.
2. Improved Security and Maintainability
By restricting access to internal APIs, the module system prevents accidental (or malicious) use of unstable JDK internals.
3. Clearer Dependencies
Modules make dependencies explicit. No more guessing which libraries a component needs.
4. Better Tooling and Diagnostics
Tools like jdeps
analyze dependencies and suggest module configurations:
jdeps --module-path lib/ --require-recursive myapp.jar
Challenges and Criticisms
Although its benefits, adoption hasn't been universal:
- Migration complexity : Large legacy apps using classpath and reflection (eg, OSGi, Spring ClassPathXmlApplicationContext) faced breakage.
- Split packages : Two modules can't export the same package—common in older libraries.
- Reflection restrictions : Code that relied on accessing internal JDK APIs (eg, for performance tricks) now fails unless
--add-opens
is used. - Learning curve : Understanding
requires
,exports
,opens
,uses
, andprovides
take time.
Modern Usage and Best Practices
Even if you don't write module-info.java
files, the module system affects you:
- Unnamed modules : JARs on the classpath becomes "unnamed modules" and can read all named modules—but they export nothing.
- Automatic modules : JARs on the module path with no
module-info
are treated as modules with implied names and exports. - Hybrid approach : Many apps still use the classpath, but benefit from strong encapsulation in the JDK.
Best practices :
- Use modules for new projects when possible.
- Prefer
jlink
for production deployments. - Avoid
--add-opens
and--illegal-access
in production. - Keep internal APIs truly internal.
Conclusion
Project Jigsaw wasn't just a feature—it was a platform overhaul . It made Java more modular, secure, and scalable for modern development, especially in cloud-native environments. While adoption has been graduate and sometimes painful, the benefits in reliability, performance, and deployment efficiency are clear.
For developers, understanding the module system is now essential—not just for using the latest Java features, but for building robust, maintained systems.
Basically, if you're shipping Java apps today, the module system is already shaping how your code runs—whether you see it or not.
The above is the detailed content of The Evolution of the Java Module System (Project Jigsaw). For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undress AI Tool
Undress images for free

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

Maven is a standard tool for Java project management and construction. The answer lies in the fact that it uses pom.xml to standardize project structure, dependency management, construction lifecycle automation and plug-in extensions; 1. Use pom.xml to define groupId, artifactId, version and dependencies; 2. Master core commands such as mvnclean, compile, test, package, install and deploy; 3. Use dependencyManagement and exclusions to manage dependency versions and conflicts; 4. Organize large applications through multi-module project structure and are managed uniformly by the parent POM; 5.

SetupaMaven/GradleprojectwithJAX-RSdependencieslikeJersey;2.CreateaRESTresourceusingannotationssuchas@Pathand@GET;3.ConfiguretheapplicationviaApplicationsubclassorweb.xml;4.AddJacksonforJSONbindingbyincludingjersey-media-json-jackson;5.DeploytoaJakar

Understand the core components of blockchain, including blocks, hashs, chain structures, consensus mechanisms and immutability; 2. Create a Block class that contains data, timestamps, previous hash and Nonce, and implement SHA-256 hash calculation and proof of work mining; 3. Build a Blockchain class to manage block lists, initialize the Genesis block, add new blocks and verify the integrity of the chain; 4. Write the main test blockchain, add transaction data blocks in turn and output chain status; 5. Optional enhancement functions include transaction support, P2P network, digital signature, RESTAPI and data persistence; 6. You can use Java blockchain libraries such as HyperledgerFabric, Web3J or Corda for production-level opening

@property decorator is used to convert methods into properties to implement the reading, setting and deletion control of properties. 1. Basic usage: define read-only attributes through @property, such as area calculated based on radius and accessed directly; 2. Advanced usage: use @name.setter and @name.deleter to implement attribute assignment verification and deletion operations; 3. Practical application: perform data verification in setters, such as BankAccount to ensure that the balance is not negative; 4. Naming specification: internal variables are prefixed, property method names are consistent with attributes, and unified access control is used to improve code security and maintainability.

First, use JavaScript to obtain the user system preferences and locally stored theme settings, and initialize the page theme; 1. The HTML structure contains a button to trigger topic switching; 2. CSS uses: root to define bright theme variables, .dark-mode class defines dark theme variables, and applies these variables through var(); 3. JavaScript detects prefers-color-scheme and reads localStorage to determine the initial theme; 4. Switch the dark-mode class on the html element when clicking the button, and saves the current state to localStorage; 5. All color changes are accompanied by 0.3 seconds transition animation to enhance the user

Yes, a common CSS drop-down menu can be implemented through pure HTML and CSS without JavaScript. 1. Use nested ul and li to build a menu structure; 2. Use the:hover pseudo-class to control the display and hiding of pull-down content; 3. Set position:relative for parent li, and the submenu is positioned using position:absolute; 4. The submenu defaults to display:none, which becomes display:block when hovered; 5. Multi-level pull-down can be achieved through nesting, combined with transition, and add fade-in animations, and adapted to mobile terminals with media queries. The entire solution is simple and does not require JavaScript support, which is suitable for large

To generate hash values using Java, it can be implemented through the MessageDigest class. 1. Get an instance of the specified algorithm, such as MD5 or SHA-256; 2. Call the .update() method to pass in the data to be encrypted; 3. Call the .digest() method to obtain a hash byte array; 4. Convert the byte array into a hexadecimal string for reading; for inputs such as large files, read in chunks and call .update() multiple times; it is recommended to use SHA-256 instead of MD5 or SHA-1 to ensure security.

Use datetime.strptime() to convert date strings into datetime object. 1. Basic usage: parse "2023-10-05" as datetime object through "%Y-%m-%d"; 2. Supports multiple formats such as "%m/%d/%Y" to parse American dates, "%d/%m/%Y" to parse British dates, "%b%d,%Y%I:%M%p" to parse time with AM/PM; 3. Use dateutil.parser.parse() to automatically infer unknown formats; 4. Use .d
