SlideShare a Scribd company logo
Java 9 / Jigsaw
Modularisation & more
Presenters
Simon Maple
@sjmaple
Mani Sarkar
@theNeomatrix369
Hosts - Atlanta JUG
Pratik Patel
@prpatel
Vince May
@vincentmayers
Our guest
Heather VanCura
@heathervc
Agenda
- Session 1: Introduction
- What is meant by Modularisation in Java 9?
- Session 2: JLink
- Lunch break: lunch + 10/15 minute optional jigsaw session
- Session 3: Migrating non-modular app to Java 9 or JShell
- Feedback
- Contribution
- Resources
How to share your (live) feedback with us?
Discussion/technical corner, share your thoughts, code snippets,
issues, feedback with us while you code away...
http://bit.ly/J9HackDay-AJUG-feedback
We have left a few
issues for you to find,
investigate, solve, report
to us or the OpenJDK /
JDK9 team
Setup
Is everyone setup, and ready to go?
http://bit.ly/J9HackDay-repo
You have this link via email / meetup message!
Read through till the end of the README.md
Session 1: Introduction: Java 9 modularisation
15 minutes
What is meant by Modularisation in Java 9?
JDK
module java.base
package java.io
class Console
...
package java.lang
class String
...
module java.logging
package java.util.logging
class FileHandler
class LogManager
...
module java.sql
package java.sql
class Connection
class SqlData
...
Java, the language: split into modules
modules...
packages...
classes...
What is meant by Modularisation in Java 9?
java.base
java.sql
other
modules...
java.logging
Java, the language: dependency graph
java.xml
implicit implicit
explicit
(requires)
explicit
(requires)
implicit
JDK
What is meant by Modularisation in Java 9?
Java, the language: dependency graph
java.base
java.sql
other
modules...
java.logging java.xml
implicit implicit
explicit
(requires)
explicit
(requires)
implicit
JDK
Our Java
applications
explicit
(requires)
explicit
implicit
What is meant by Modularisation in Java 9?
Pre-Java 9
Java 9/Jigsaw
src/main/java
package a.b.c
class p
class q
package m.n.o
class s
class t
src/main/java
module a.b.c
package a.b.c
class p
class q
module m.n.o
package m.n.o
class s
class t
Structure of
a typical
Java app.
containing
packages...
Create your own
modules
containing
packages, classes...
What is meant by Modularisation in Java 9?
Typical package structure Modules contain packages
Credits to Paul Bakker & Sander Mak
package books.api.entities
classes
package bookstore.api.service
What is looks like from the file system?
What is meant by Modularisation in Java 9?
Typical package structure Modules contain packages
Credits to Paul Bakker & Sander Mak
contains module
visibility
(readability) &
dependency info
module books.api contains
package books.api.entities
package books.api.service
modules
What is looks like from the file system?
What is meant by Modularisation in Java 9?
module com.abc {
requires com.abc.pqr;
requires transitive com.xyz.abc;
exports com.abc.def.alpha;
exports com.abc.pqr.beta to
com.ijk.mno,
com.lmn.stu;
uses java.network.Driver;
provides java.sql.Driver with com.mno.def.Driver;
}
module
definition
defines dependencies of module, to modules
com.abc.pqr & com.xyz.abc
transitive keyword defines
implicit dependency
module name
How is module dependencies are defined in Java 9?
module-info.java
What is meant by Modularisation in Java 9?
module com.abc {
requires com.abc.pqr;
requires transitive com.xyz.abc;
exports com.abc.def.alpha;
exports com.abc.pqr.beta to
com.ijk.mno,
com.lmn.stu;
uses java.network.Driver;
provides java.sql.Driver with com.mno.def.Driver;
}
module
definition
make all & only public types in specified
packages available to other modules
How is module dependencies are defined in Java 9?
module name
… or make available
to specified modules
module-info.java
What is meant by Modularisation in Java 9?
module com.abc {
requires com.abc.pqr;
requires transitive com.xyz.abc;
exports com.abc.def.alpha;
exports com.abc.pqr.beta to
com.ijk.mno,
com.lmn.stu;
uses java.network.Driver;
provides java.sql.Driver with com.mno.def.Driver;
}
module-info.java
module
definition
this module publishes
a service provider
this module uses a service provider
published by another module
module name
How is module dependencies are defined in Java 9?
Link to all the exercises!
http://bit.ly/J9Hackday-exercises
Session 1: Hands-on: Java 9 modularisation
60 minutes
http://bit.ly/J9HackDay-session-1-jigsaw-intro
(http://bit.ly/J9HackDay-repo)
Session 1: feedback
15 minutes
http://bit.ly/J9HackDay-AJUG-feedback
Lunch break
60 minutes
Short 10/15 minutes covering intro/background/fundamentals (talk while having a bite of food and drink)
What is meant by Modularisation in Java 9?
A bit of fundamentals and background before we get to the answer
What is meant by Modularisation in Java 9?
modularisation
Pre-Java 9 Java 9
Anomalies
OpenJDK& JDK
What is meant by Modularisation in Java 9?
How we perceive the JDK/JRE from a developer’s / end-user’s perspective?
JDK or
JRE
IBM
Other
vendors
Oracle download
Create
Client
Apps
distribute
Client
Apps +
bundle
JRE
What is meant by Modularisation in Java 9?
How the maintainers of Java perceive it?
Distribute
built apps
+ bundle
JDK
IBM
Other
vendors
Oracle build downloadOpenJDK JDK
What is meant by Modularisation in Java 9?
Modularisation of OpenJDK sources (JEP 201 and related JEPs)
Binary
compatible
JDK
re-organise rebuild
OpenJDK
source
Refactored
OpenJDK
source
Repository
JDK
re-organise
Improved layout of
source folders in
the JDK repository
What is meant by Modularisation in Java 9?
Modularisation of Runtime Images (JEP 220 and related JEPs)
Binary
compatible
JDK
re-organise rebuild
Runtime
JDK
Optimised
(modular)
JDK
Runtime
Traditional
Runtime JDK
Image
re-organise
A more compact
Runtime JDK Image
What is meant by Modularisation in Java 9?
Modularisation of Java Packages and Application Packaging (JEP 275 and related JEPs)
Modular Java 9
application +
custom JDK
compiles creates
Modularised
JDK Runtime
Modular
Java 9
source
JLink Smaller JDK footprint
Java 9
applicationcompiles creates
Modularised
JDK Runtime
Non-modular
Java 9 source
Binary compatible
creates
What is meant by Modularisation in Java 9?
JSR 376: Java Platform Module System played the primary role
http://openjdk.java.net/projects/jigsaw/spec/
What is meant by Modularisation in Java 9?
JEPs that lead to all the new features in Java 9 (including
Jigsaw):
- 200: The Modular JDK
- 201: Modular Source Code
- 220: Modular Run-Time Images (depends on JEP 162)
- 260: Encapsulate Most Internal APIs (no dependencies)
- 261: Module System (dependens on JEP 220, related to JEP 238)
- 282: jlink: The Java Linker (replaces implementation of JEP 220)
- 275: Modular Java Application Packaging
- 222: jshell: The Java Shell (Read-Eval-Print Loop)
- 193: Variable Handles
- 110: HTTP 2 Client
- 238: Multi-Release JAR Files
- 158: Unified JVM Logging
- G1 related JEPs (3)
- JEPs related to a number of security improvements
- JEPs related to a number of platform improvements
- >>> Many, many more JEPs, see the Java 9 JEPs list for further details <<<
What is meant by Modularisation in Java 9?
JDK 9& Jigsaw feature distribution
...
Other
JDK 9
features
Jigsaw
...
...
...
... ... ... ...
...
...
...
...
...
...
...
...
Why Modularisation in Java 9?
But, why?
It’s been worked on for about a decade:
- Reliable Configuration
- define module dependencies
- resolve classpath issues
- Strong Encapsulation
- define or hiding away what’s not intended or necessary
for public access
- JDK internal APIs (sun.misc.unsafe, security,
etc…)
- within APIs of our own applications
Why Modularisation in Java 9?
Other side effects and benefits:
- Decluttering of code bases (loose coupling & high cohesion)
- OpenJDK sources
- JDK sources
- Our Java App sources (post migration and refactoring)
- Customised runtime JDK (smaller footprint)
- Highly desirable for IoT, arduino/embedded devices,
etc…
- Improve distribution and runtime performance
- Any more?
Why Modularisation in Java 9?
Why Modularisation in Java 9?
Important Java 9
concepts & terminologies
Concepts & terminologies
- module
- modular JAR
- accessibility
- implied readability
- automatic module
- unnamed module
- open module
- open package
- split packages
Important Java 9 Concepts & Terminologies
Credits: Oleg Tsal-Tsalko & Nicolai Parlog
module
- named (via module-info.java)
- self-describing collection of code and data
- declares which other modules it requires
- exports one or more packages to other
modules
Important Java 9 Concepts & Terminologies
modular JAR
- like any other JAR file
- contains module-info.class in its root
directory
Important Java 9 Concepts & Terminologies
accessibility
(accessibility of types between modules)
- type must be public
- module exports the package containing
the type
- module depending on it declares it as
required (requires)
Important Java 9 Concepts & Terminologies
implied readability
(direct & implied readability)
Important Java 9 Concepts & Terminologies
readsmodule A
requires B
module B
exports ...
readsmodule A
requires B
module B
exports …
requires C
reads module C
exports ...
module A indirectly reads module C
module A
directly reads
module B
automatic module
- any (non-modular) JAR file placed on the MODULEPATH
- module name is derived from the jar name
- can have no module name if compiler fails to derive from the jar name
- does not contain the module descriptor file module-info.java
- exports everything
- reads all modules including unnamed modules
- not open for reflective access (unless directives are used)
Important Java 9 Concepts & Terminologies
named module
- modular JAR file placed on the MODULEPATH
- module name is derived from the module-info.java
descriptor file
- exports only packages that are declared exports
- reads only modules declared as requires
- not open for deep reflective access (unless directives are
used)
Important Java 9 Concepts & Terminologies
unnamed module
- any (non-modular) JAR file placed on the CLASSPATH
- module name is not derived from the jar name
- does not contain module-info.java descriptor file
- exports everything
- reads all modules except cannot read unnamed modules
- open for deep reflective access (for backward
compatibility)
Important Java 9 Concepts & Terminologies
automatic v/s unnamed modules
- they are the same, except
- automatic module: any (non-modular) JAR file placed
on the MODULEPATH
- unnamed module: any (non-modular) JAR file placed on
the CLASSPATH
- automatic modules get their names from the jar,
unnamed modules as the name states, is not named
Important Java 9 Concepts & Terminologies
open module
- a module declared for deep reflective access by other
modules (to help migration)
- declared in the module-info.java
Important Java 9 Concepts & Terminologies
open module foo.bar {
exports com.foo.bar;
requires hibernate.core;
requires hibernate.entitymanager;
}
open module
open package
- a package declared for deep reflective access by other
modules (to help migration)
- declared in the module-info.java
Important Java 9 Concepts & Terminologies
module foo.bar {
exports com.foo.bar;
opens com.foo.bar.model;
requires hibernate.core;
requires hibernate.entitymanager;
}
open package
split packages
- Two or more modules containing the same package
results
- strictly checked for Java 9 modules (named)
- not checked for unnamed modules
- causes the package to become invisible
Important Java 9 Concepts & Terminologies
Not everything can be covered but let’s find out about these topics:
- difference between classpath and module path
- kill switch (remove Jigsaw restrictions):
- java --permit-illegal-access …
- Jlink CLI option: --launcher
- maven, ant or gradle integrations
- and many more topics…
- checkout the resources on http://bit.ly/Java-9-Resources
So many things to cover!
https://github.com/accso/java9-jigsaw-depvis
Visualise your dependencies!
Session 2: Introduction: JLink
10 minutes
Session 2: Introduction: JLink
Create a package
distributable, that
runs on any platform,
but needs a platform
specific JDK
JDK (javac)
Your App
packages
& classes
Your App
package
(distributable)
JVM, the
Platform
Java, the
language
(packages &
classes)
Any JRE/JDK
compiles
creates
Pre-Java 9
depends on (needs), to run
Session 2: Introduction: JLink
JDK
modules
JLink
JVM, the
Platform
Java, the
language (JDK
modules)
Your App
modules
Create standalone
distributable (smaller
footprint), that runs
on a specific platform
Your App
modules
JDK compiles
creates
Java 9
Session 2: Hands-on: JLink
40 minutes
http://bit.ly/J9HackDay-session-2-jlink
(http://bit.ly/J9HackDay-repo)
Session 2: feedback
10 minutes
http://bit.ly/J9HackDay-AJUG-feedback
Session 3: Introduction: Migration or JShell
15 minutes
Session 3: Introduction: Migration or JShell
Session 3 hands-on: Migration or JShell
60 minutes
http://bit.ly/J9HackDay-session-3-jshell
(http://bit.ly/J9HackDay-repo)
Session 3 & overall: feedback
15-30 minutes
http://bit.ly/J9HackDay-AJUG-feedback
Contribute
Don’t like something or like something a lot,
want to contribute to make things better?
http://bit.ly/AdoptOpenJDK-contribute
Feedback
We value your feedback, make Java better
with your constructive feedback
http://bit.ly/AdoptOpenJDK-feedback
Resources
Want to know about the other features of Java 9:
http://bit.ly/Java-9-Resources
Thank you to all
Thank you for your continued support
9
@atlantajug
@virtualJug
@adoptopenjdk
@openjdk
@jcp_org
@java

More Related Content

PDF
JCP & The Future of Java
PDF
Migrating Speedment to Java 9
PDF
Java 9 / Jigsaw - LJC / VJUG session (hackday session)
PPSX
Introduction to Java
PPTX
Modularity of the Java Platform (OSGi, Jigsaw and Penrose)
PPT
Rollin onj Rubyv3
PDF
Java EE 6 workshop at Dallas Tech Fest 2011
PDF
Bea weblogic job_interview_preparation_guide
JCP & The Future of Java
Migrating Speedment to Java 9
Java 9 / Jigsaw - LJC / VJUG session (hackday session)
Introduction to Java
Modularity of the Java Platform (OSGi, Jigsaw and Penrose)
Rollin onj Rubyv3
Java EE 6 workshop at Dallas Tech Fest 2011
Bea weblogic job_interview_preparation_guide

What's hot (20)

PPTX
Future of Java EE with Java SE 8
PDF
Sun Java EE 6 Overview
PDF
Java 7 workshop
PDF
Oracle History #5
PDF
Java EE6 CodeCamp16 oct 2010
PDF
The State of Java under Oracle at JCertif 2011
PDF
Java one 2015 [con3339]
PDF
History of java
PDF
Java EE 6 Component Model Explained
PDF
Advance Java Tutorial | J2EE, Java Servlets, JSP, JDBC | Java Certification T...
PDF
Java for XPages Development
PDF
Java EE 6 & GlassFish 3
PDF
Why should i switch to Java SE 7
PPTX
Java EE 8
PDF
Connect 2014 JMP101: Java for XPages Development
PPT
Developing modular Java applications
PPTX
[RakutenTechConf2013] [E-3] Financial Web System with Java EE 6
PDF
Overview of Java EE 6 by Roberto Chinnici at SFJUG
PDF
History of Java 2/2
PDF
Java EE Revisits GoF Design Patterns
Future of Java EE with Java SE 8
Sun Java EE 6 Overview
Java 7 workshop
Oracle History #5
Java EE6 CodeCamp16 oct 2010
The State of Java under Oracle at JCertif 2011
Java one 2015 [con3339]
History of java
Java EE 6 Component Model Explained
Advance Java Tutorial | J2EE, Java Servlets, JSP, JDBC | Java Certification T...
Java for XPages Development
Java EE 6 & GlassFish 3
Why should i switch to Java SE 7
Java EE 8
Connect 2014 JMP101: Java for XPages Development
Developing modular Java applications
[RakutenTechConf2013] [E-3] Financial Web System with Java EE 6
Overview of Java EE 6 by Roberto Chinnici at SFJUG
History of Java 2/2
Java EE Revisits GoF Design Patterns
Ad

Similar to Java 9 / Jigsaw - AJUG/VJUG session (20)

PPT
Java 9 Module System
PPTX
Java 9 Modularity and Project Jigsaw
PPTX
What's New in Java 9
PDF
JavaOne 2016: Life after Modularity
PPSX
Java 9 and the impact on Maven Projects (JavaOne 2016)
PPTX
Java 9: Deep Dive into Modularity and Dealing with Migration Issues
PDF
Java 9 New Features
PPTX
Modular Java
PPSX
Java9 and the impact on Maven Projects (JFall 2016)
PPTX
Modularity of The Java Platform Javaday (http://javaday.org.ua/)
PPT
Java8 - Under the hood
PPTX
Preparing for java 9 modules upload
PDF
Modules all the way down: OSGi and the Java Platform Module System
PPSX
Java 9 and the impact on Maven Projects (ApacheCon Europe 2016)
PPTX
Java Platform Module System
PPTX
Leaner microservices with Java 10
PDF
Haj 4344-java se 9 and the application server-1
PPTX
Modules in Java? Finally! (OpenJDK 9 Jigsaw, JSR376)
PDF
Jigsaw - Javaforum 2015Q4
Java 9 Module System
Java 9 Modularity and Project Jigsaw
What's New in Java 9
JavaOne 2016: Life after Modularity
Java 9 and the impact on Maven Projects (JavaOne 2016)
Java 9: Deep Dive into Modularity and Dealing with Migration Issues
Java 9 New Features
Modular Java
Java9 and the impact on Maven Projects (JFall 2016)
Modularity of The Java Platform Javaday (http://javaday.org.ua/)
Java8 - Under the hood
Preparing for java 9 modules upload
Modules all the way down: OSGi and the Java Platform Module System
Java 9 and the impact on Maven Projects (ApacheCon Europe 2016)
Java Platform Module System
Leaner microservices with Java 10
Haj 4344-java se 9 and the application server-1
Modules in Java? Finally! (OpenJDK 9 Jigsaw, JSR376)
Jigsaw - Javaforum 2015Q4
Ad

More from Mani Sarkar (17)

PDF
How to contribute to Adopt OpenJDK?
PDF
Cli in the browser
PDF
Theory of constraints
PDF
Kanban kata
PDF
Refactoring developer habits
PDF
Essential technical skills
PDF
How is Java / JVM built ? Back then and now...
PDF
How is Java / JVM built ? Adopt OpenJDK is your answer !
PDF
Adopt OpenJDK the past, the present & the future
PDF
Adopt OpenJDK presentation (slide deck)
PDF
Adopt OpenJDK, Betterrev blind ignite presentation
PDF
Fosdem2014 fromwebrevtobetterrevbryantsarkar-140203131215-phpapp02
PPTX
Java2 days 2013-lambda
PPTX
Ljc conf open jdk betterrev bof
PPTX
Sonar qube to impove code quality
PPTX
Java2 days 2013-j-treg
PDF
Leaning on the two Ts
How to contribute to Adopt OpenJDK?
Cli in the browser
Theory of constraints
Kanban kata
Refactoring developer habits
Essential technical skills
How is Java / JVM built ? Back then and now...
How is Java / JVM built ? Adopt OpenJDK is your answer !
Adopt OpenJDK the past, the present & the future
Adopt OpenJDK presentation (slide deck)
Adopt OpenJDK, Betterrev blind ignite presentation
Fosdem2014 fromwebrevtobetterrevbryantsarkar-140203131215-phpapp02
Java2 days 2013-lambda
Ljc conf open jdk betterrev bof
Sonar qube to impove code quality
Java2 days 2013-j-treg
Leaning on the two Ts

Recently uploaded (20)

PDF
System and Network Administraation Chapter 3
PDF
Which alternative to Crystal Reports is best for small or large businesses.pdf
PDF
Addressing The Cult of Project Management Tools-Why Disconnected Work is Hold...
PDF
Wondershare Filmora 15 Crack With Activation Key [2025
PDF
Internet Downloader Manager (IDM) Crack 6.42 Build 41
PDF
T3DD25 TYPO3 Content Blocks - Deep Dive by André Kraus
PDF
Navsoft: AI-Powered Business Solutions & Custom Software Development
PPTX
CHAPTER 2 - PM Management and IT Context
PDF
Why TechBuilder is the Future of Pickup and Delivery App Development (1).pdf
PDF
AI in Product Development-omnex systems
PDF
Design an Analysis of Algorithms I-SECS-1021-03
PPTX
Transform Your Business with a Software ERP System
PDF
Raksha Bandhan Grocery Pricing Trends in India 2025.pdf
PDF
Nekopoi APK 2025 free lastest update
PDF
Flood Susceptibility Mapping Using Image-Based 2D-CNN Deep Learnin. Overview ...
PDF
How to Choose the Right IT Partner for Your Business in Malaysia
PDF
Design an Analysis of Algorithms II-SECS-1021-03
PDF
Digital Strategies for Manufacturing Companies
PPTX
ai tools demonstartion for schools and inter college
PPTX
Introduction to Artificial Intelligence
System and Network Administraation Chapter 3
Which alternative to Crystal Reports is best for small or large businesses.pdf
Addressing The Cult of Project Management Tools-Why Disconnected Work is Hold...
Wondershare Filmora 15 Crack With Activation Key [2025
Internet Downloader Manager (IDM) Crack 6.42 Build 41
T3DD25 TYPO3 Content Blocks - Deep Dive by André Kraus
Navsoft: AI-Powered Business Solutions & Custom Software Development
CHAPTER 2 - PM Management and IT Context
Why TechBuilder is the Future of Pickup and Delivery App Development (1).pdf
AI in Product Development-omnex systems
Design an Analysis of Algorithms I-SECS-1021-03
Transform Your Business with a Software ERP System
Raksha Bandhan Grocery Pricing Trends in India 2025.pdf
Nekopoi APK 2025 free lastest update
Flood Susceptibility Mapping Using Image-Based 2D-CNN Deep Learnin. Overview ...
How to Choose the Right IT Partner for Your Business in Malaysia
Design an Analysis of Algorithms II-SECS-1021-03
Digital Strategies for Manufacturing Companies
ai tools demonstartion for schools and inter college
Introduction to Artificial Intelligence

Java 9 / Jigsaw - AJUG/VJUG session

  • 1. Java 9 / Jigsaw Modularisation & more
  • 3. Hosts - Atlanta JUG Pratik Patel @prpatel Vince May @vincentmayers
  • 5. Agenda - Session 1: Introduction - What is meant by Modularisation in Java 9? - Session 2: JLink - Lunch break: lunch + 10/15 minute optional jigsaw session - Session 3: Migrating non-modular app to Java 9 or JShell - Feedback - Contribution - Resources
  • 6. How to share your (live) feedback with us? Discussion/technical corner, share your thoughts, code snippets, issues, feedback with us while you code away... http://bit.ly/J9HackDay-AJUG-feedback We have left a few issues for you to find, investigate, solve, report to us or the OpenJDK / JDK9 team
  • 7. Setup Is everyone setup, and ready to go? http://bit.ly/J9HackDay-repo You have this link via email / meetup message! Read through till the end of the README.md
  • 8. Session 1: Introduction: Java 9 modularisation 15 minutes
  • 9. What is meant by Modularisation in Java 9? JDK module java.base package java.io class Console ... package java.lang class String ... module java.logging package java.util.logging class FileHandler class LogManager ... module java.sql package java.sql class Connection class SqlData ... Java, the language: split into modules modules... packages... classes...
  • 10. What is meant by Modularisation in Java 9? java.base java.sql other modules... java.logging Java, the language: dependency graph java.xml implicit implicit explicit (requires) explicit (requires) implicit JDK
  • 11. What is meant by Modularisation in Java 9? Java, the language: dependency graph java.base java.sql other modules... java.logging java.xml implicit implicit explicit (requires) explicit (requires) implicit JDK Our Java applications explicit (requires) explicit implicit
  • 12. What is meant by Modularisation in Java 9? Pre-Java 9 Java 9/Jigsaw src/main/java package a.b.c class p class q package m.n.o class s class t src/main/java module a.b.c package a.b.c class p class q module m.n.o package m.n.o class s class t Structure of a typical Java app. containing packages... Create your own modules containing packages, classes...
  • 13. What is meant by Modularisation in Java 9? Typical package structure Modules contain packages Credits to Paul Bakker & Sander Mak package books.api.entities classes package bookstore.api.service What is looks like from the file system?
  • 14. What is meant by Modularisation in Java 9? Typical package structure Modules contain packages Credits to Paul Bakker & Sander Mak contains module visibility (readability) & dependency info module books.api contains package books.api.entities package books.api.service modules What is looks like from the file system?
  • 15. What is meant by Modularisation in Java 9? module com.abc { requires com.abc.pqr; requires transitive com.xyz.abc; exports com.abc.def.alpha; exports com.abc.pqr.beta to com.ijk.mno, com.lmn.stu; uses java.network.Driver; provides java.sql.Driver with com.mno.def.Driver; } module definition defines dependencies of module, to modules com.abc.pqr & com.xyz.abc transitive keyword defines implicit dependency module name How is module dependencies are defined in Java 9? module-info.java
  • 16. What is meant by Modularisation in Java 9? module com.abc { requires com.abc.pqr; requires transitive com.xyz.abc; exports com.abc.def.alpha; exports com.abc.pqr.beta to com.ijk.mno, com.lmn.stu; uses java.network.Driver; provides java.sql.Driver with com.mno.def.Driver; } module definition make all & only public types in specified packages available to other modules How is module dependencies are defined in Java 9? module name … or make available to specified modules module-info.java
  • 17. What is meant by Modularisation in Java 9? module com.abc { requires com.abc.pqr; requires transitive com.xyz.abc; exports com.abc.def.alpha; exports com.abc.pqr.beta to com.ijk.mno, com.lmn.stu; uses java.network.Driver; provides java.sql.Driver with com.mno.def.Driver; } module-info.java module definition this module publishes a service provider this module uses a service provider published by another module module name How is module dependencies are defined in Java 9?
  • 18. Link to all the exercises! http://bit.ly/J9Hackday-exercises
  • 19. Session 1: Hands-on: Java 9 modularisation 60 minutes http://bit.ly/J9HackDay-session-1-jigsaw-intro (http://bit.ly/J9HackDay-repo)
  • 20. Session 1: feedback 15 minutes http://bit.ly/J9HackDay-AJUG-feedback
  • 21. Lunch break 60 minutes Short 10/15 minutes covering intro/background/fundamentals (talk while having a bite of food and drink)
  • 22. What is meant by Modularisation in Java 9? A bit of fundamentals and background before we get to the answer
  • 23. What is meant by Modularisation in Java 9? modularisation Pre-Java 9 Java 9 Anomalies OpenJDK& JDK
  • 24. What is meant by Modularisation in Java 9? How we perceive the JDK/JRE from a developer’s / end-user’s perspective? JDK or JRE IBM Other vendors Oracle download Create Client Apps distribute Client Apps + bundle JRE
  • 25. What is meant by Modularisation in Java 9? How the maintainers of Java perceive it? Distribute built apps + bundle JDK IBM Other vendors Oracle build downloadOpenJDK JDK
  • 26. What is meant by Modularisation in Java 9? Modularisation of OpenJDK sources (JEP 201 and related JEPs) Binary compatible JDK re-organise rebuild OpenJDK source Refactored OpenJDK source Repository JDK re-organise Improved layout of source folders in the JDK repository
  • 27. What is meant by Modularisation in Java 9? Modularisation of Runtime Images (JEP 220 and related JEPs) Binary compatible JDK re-organise rebuild Runtime JDK Optimised (modular) JDK Runtime Traditional Runtime JDK Image re-organise A more compact Runtime JDK Image
  • 28. What is meant by Modularisation in Java 9? Modularisation of Java Packages and Application Packaging (JEP 275 and related JEPs) Modular Java 9 application + custom JDK compiles creates Modularised JDK Runtime Modular Java 9 source JLink Smaller JDK footprint Java 9 applicationcompiles creates Modularised JDK Runtime Non-modular Java 9 source Binary compatible creates
  • 29. What is meant by Modularisation in Java 9? JSR 376: Java Platform Module System played the primary role http://openjdk.java.net/projects/jigsaw/spec/
  • 30. What is meant by Modularisation in Java 9? JEPs that lead to all the new features in Java 9 (including Jigsaw): - 200: The Modular JDK - 201: Modular Source Code - 220: Modular Run-Time Images (depends on JEP 162) - 260: Encapsulate Most Internal APIs (no dependencies) - 261: Module System (dependens on JEP 220, related to JEP 238) - 282: jlink: The Java Linker (replaces implementation of JEP 220) - 275: Modular Java Application Packaging - 222: jshell: The Java Shell (Read-Eval-Print Loop) - 193: Variable Handles - 110: HTTP 2 Client - 238: Multi-Release JAR Files - 158: Unified JVM Logging - G1 related JEPs (3) - JEPs related to a number of security improvements - JEPs related to a number of platform improvements - >>> Many, many more JEPs, see the Java 9 JEPs list for further details <<<
  • 31. What is meant by Modularisation in Java 9? JDK 9& Jigsaw feature distribution ... Other JDK 9 features Jigsaw ... ... ... ... ... ... ... ... ... ... ... ... ... ... ...
  • 32. Why Modularisation in Java 9? But, why?
  • 33. It’s been worked on for about a decade: - Reliable Configuration - define module dependencies - resolve classpath issues - Strong Encapsulation - define or hiding away what’s not intended or necessary for public access - JDK internal APIs (sun.misc.unsafe, security, etc…) - within APIs of our own applications Why Modularisation in Java 9?
  • 34. Other side effects and benefits: - Decluttering of code bases (loose coupling & high cohesion) - OpenJDK sources - JDK sources - Our Java App sources (post migration and refactoring) - Customised runtime JDK (smaller footprint) - Highly desirable for IoT, arduino/embedded devices, etc… - Improve distribution and runtime performance - Any more? Why Modularisation in Java 9?
  • 35. Why Modularisation in Java 9? Important Java 9 concepts & terminologies
  • 36. Concepts & terminologies - module - modular JAR - accessibility - implied readability - automatic module - unnamed module - open module - open package - split packages Important Java 9 Concepts & Terminologies Credits: Oleg Tsal-Tsalko & Nicolai Parlog
  • 37. module - named (via module-info.java) - self-describing collection of code and data - declares which other modules it requires - exports one or more packages to other modules Important Java 9 Concepts & Terminologies
  • 38. modular JAR - like any other JAR file - contains module-info.class in its root directory Important Java 9 Concepts & Terminologies
  • 39. accessibility (accessibility of types between modules) - type must be public - module exports the package containing the type - module depending on it declares it as required (requires) Important Java 9 Concepts & Terminologies
  • 40. implied readability (direct & implied readability) Important Java 9 Concepts & Terminologies readsmodule A requires B module B exports ... readsmodule A requires B module B exports … requires C reads module C exports ... module A indirectly reads module C module A directly reads module B
  • 41. automatic module - any (non-modular) JAR file placed on the MODULEPATH - module name is derived from the jar name - can have no module name if compiler fails to derive from the jar name - does not contain the module descriptor file module-info.java - exports everything - reads all modules including unnamed modules - not open for reflective access (unless directives are used) Important Java 9 Concepts & Terminologies
  • 42. named module - modular JAR file placed on the MODULEPATH - module name is derived from the module-info.java descriptor file - exports only packages that are declared exports - reads only modules declared as requires - not open for deep reflective access (unless directives are used) Important Java 9 Concepts & Terminologies
  • 43. unnamed module - any (non-modular) JAR file placed on the CLASSPATH - module name is not derived from the jar name - does not contain module-info.java descriptor file - exports everything - reads all modules except cannot read unnamed modules - open for deep reflective access (for backward compatibility) Important Java 9 Concepts & Terminologies
  • 44. automatic v/s unnamed modules - they are the same, except - automatic module: any (non-modular) JAR file placed on the MODULEPATH - unnamed module: any (non-modular) JAR file placed on the CLASSPATH - automatic modules get their names from the jar, unnamed modules as the name states, is not named Important Java 9 Concepts & Terminologies
  • 45. open module - a module declared for deep reflective access by other modules (to help migration) - declared in the module-info.java Important Java 9 Concepts & Terminologies open module foo.bar { exports com.foo.bar; requires hibernate.core; requires hibernate.entitymanager; } open module
  • 46. open package - a package declared for deep reflective access by other modules (to help migration) - declared in the module-info.java Important Java 9 Concepts & Terminologies module foo.bar { exports com.foo.bar; opens com.foo.bar.model; requires hibernate.core; requires hibernate.entitymanager; } open package
  • 47. split packages - Two or more modules containing the same package results - strictly checked for Java 9 modules (named) - not checked for unnamed modules - causes the package to become invisible Important Java 9 Concepts & Terminologies
  • 48. Not everything can be covered but let’s find out about these topics: - difference between classpath and module path - kill switch (remove Jigsaw restrictions): - java --permit-illegal-access … - Jlink CLI option: --launcher - maven, ant or gradle integrations - and many more topics… - checkout the resources on http://bit.ly/Java-9-Resources So many things to cover!
  • 50. Session 2: Introduction: JLink 10 minutes
  • 51. Session 2: Introduction: JLink Create a package distributable, that runs on any platform, but needs a platform specific JDK JDK (javac) Your App packages & classes Your App package (distributable) JVM, the Platform Java, the language (packages & classes) Any JRE/JDK compiles creates Pre-Java 9 depends on (needs), to run
  • 52. Session 2: Introduction: JLink JDK modules JLink JVM, the Platform Java, the language (JDK modules) Your App modules Create standalone distributable (smaller footprint), that runs on a specific platform Your App modules JDK compiles creates Java 9
  • 53. Session 2: Hands-on: JLink 40 minutes http://bit.ly/J9HackDay-session-2-jlink (http://bit.ly/J9HackDay-repo)
  • 54. Session 2: feedback 10 minutes http://bit.ly/J9HackDay-AJUG-feedback
  • 55. Session 3: Introduction: Migration or JShell 15 minutes
  • 56. Session 3: Introduction: Migration or JShell
  • 57. Session 3 hands-on: Migration or JShell 60 minutes http://bit.ly/J9HackDay-session-3-jshell (http://bit.ly/J9HackDay-repo)
  • 58. Session 3 & overall: feedback 15-30 minutes http://bit.ly/J9HackDay-AJUG-feedback
  • 59. Contribute Don’t like something or like something a lot, want to contribute to make things better? http://bit.ly/AdoptOpenJDK-contribute
  • 60. Feedback We value your feedback, make Java better with your constructive feedback http://bit.ly/AdoptOpenJDK-feedback
  • 61. Resources Want to know about the other features of Java 9: http://bit.ly/Java-9-Resources
  • 62. Thank you to all Thank you for your continued support 9 @atlantajug @virtualJug @adoptopenjdk @openjdk @jcp_org @java