Upgrade to Pro — share decks privately, control downloads, hide ads and more …

Ein Puzzlespiel: Einführung in das Modulsystem Jigsaw in Java 9

Ein Puzzlespiel: Einführung in das Modulsystem Jigsaw in Java 9

Martin Lehmann, Kristine Schaal: „Ein Puzzlespiel: Einführung in das Modulsystem Jigsaw in Java 9“. JCON 2017, Düsseldorf, 24. Oktober 2017

https://jcon.xdev.cloud/

Martin Lehmann

October 24, 2017
Tweet

More Decks by Martin Lehmann

Other Decks in Programming

Transcript

  1. Copyright © Accso – Accelerated Solutions GmbH 1 v.3 1

    v.3.12 Ein Puzzlespiel Einführung in das Modulsystem Jigsaw in Java 9 MARTIN LEHMANN, DR. KRISTINE SCHAAL | JCON 2017 JCON2017, 24. Oktober 2017
  2. Copyright © Accso – Accelerated Solutions GmbH 2 Mit Java

    9 kommt das lange angekündigte Modulsystem Jigsaw. Jigsaw ist eine grundlegende Strukturänderung von Java-Plattform und -Sprache, mit deren Auswirkungen man sich möglichst früh beschäftigen sollte. In diesem Tutorial erläutern wir Grundlagen von Jigsaw. Wir zeigen Motive und Ziele für die Einführung eines Modulsystems. Wir geben eine Rundum-Einführung in Jigsaw zu folgenden Fragen: Warum braucht Java überhaupt ein Modulsystem? Wie profitieren Entwickler davon? Was ist ein Modul und wie definiere ich Module und Abhängigkeiten? Welche Sichtbarkeiten gibt es zwischen Modulen? Module sind sowohl Compiler- Erweiterung als auch Teil des Laufzeitsystems - wie wirkt sich das aus? Wie vertragen sich Module mit generischen Ansätzen wie Reflection oder Callbacks, auf denen eine Reihe bekannter Frameworks basieren? Welche anderen Konstrukte gibt es (Beispiel: Services)? Wie weit sind Entwicklertools wie IDEs und für Build-/ Dependency-Management auf Jigsaw eingestellt? Abstract JCON 2017 https://jcon.xdev.cloud/
  3. Copyright © Accso – Accelerated Solutions GmbH 3 Dr. Rüdiger

    Grammes, Accso - Accelerated Solutions GmbH Softwarearchitekt Dr. Rüdiger Grammes ist seit November 2011 als Principal bei der Accso – Accelerated Solutions GmbH und dort als Softwarearchitekt in verschiedenen Projekten unterwegs. [email protected] www.xing.com/profile/Ruediger_Grammes Martin Lehmann, Accso - Accelerated Solutions GmbH Cheftechnologe Martin Lehmann ist Diplom-Informatiker und arbeitet als Cheftechnologe und Softwarearchitekt bei der Accso - Accelerated Solutions GmbH. Seit Ende der 90er-Jahre wirkt er als Softwareentwickler und -architekt in der Softwareentwicklung in diversen Projekten der Individualentwicklung für Kunden verschiedener Branchen. Seit den Zeiten von Java 1.0 beschäftigt er sich mit Java als Programmiersprache und als Ökosystem. [email protected] @lemmi111171 www.xing.com/profile/Martin_Lehmann3 Dr. Kristine Schaal, Accso - Accelerated Solutions GmbH Softwarearchitektin Dr. Kristine Schaal ist als Softwarearchitektin bei der Accso - Accelerated Solutions GmbH tätig. Sie arbeitet seit fast 20 Jahren in der Softwareentwicklung und ist in Projekten der Individualentwicklung für Kunden verschiedener Branchen unterwegs, technisch überwiegend im Java-Umfeld. [email protected] @krschaal www.xing.com/profile/Kristine_Schaal
  4. Copyright © Accso – Accelerated Solutions GmbH 6 Project Jigsaw:

    JSR 376 und seine Ziele Strong Encapsulation Eine Komponente kann ihr öffentliches API definieren und den Zugriff auf Implementierungsgeheimnisse verhindern. Reliable Configuration Ablösung des Classpath (fehleranfällig, wenn Klassen mehrfach enthalten sind  Reihenfolge). Scalable Java SE Platform Die Java-Plattform selber ist nun modularisiert. Man kann individuell angepasste, „schlanke“ Plattformen bauen. JSR 376 (2014-2017) „Java Platform Module System“ (JPMS) Project Jigsaw in Java 9-Release vom 21. September 2017 enthalten. Aktuell: 9.0.1 vom 18. Oktober 2017 Enthalten: JEP 261, 200, 201, 220, 260, 282 mit Modulsystem, modularisiertem JDK und der Kapselung interner APIs
  5. Copyright © Accso – Accelerated Solutions GmbH 9 Modul :=

    Menge von Java-Packages & Resources Wird in ein „Modular JAR“ kompiliert. Dieses liegt im neuen Module-Path MP. Modul-Namen müssen eindeutig sein (erlaubt sind . und _ , aber nicht -) • „read“-Abhängigkeitsbeziehungen zu einem oder mehreren anderen Modulen • „exports“: Welche Packages des Moduls werden exportiert? (Default: nichts!) modmain Ein Modul ist ab Java 9 ein „First-Class-Citizen“ in Java. moda read exports pkg main pkg a pkga inter nal
  6. Copyright © Accso – Accelerated Solutions GmbH 14 Neu in

    Java 9: Readability und Accessibility read modmain pkg main Checks zu Compile-Zeit und zur Laufzeit von 1. neu: Readability „ich benötige dieses Modul, will darauf zugreifen“ 2. neu: Accessibility „worauf dürfen andere zugreifen?“ (unabhg. von Classloadern!) 3. Check der „alten“ Sichtbarkeitsmodifier public,protected,<package>,private de.my. package. ximpl de.my. package. internal de.my. package exports moda
  7. Copyright © Accso – Accelerated Solutions GmbH 15 Beispiel: Vier

    Module moda, modb, modc, modmain und ihr Sourcenbaum moda/ module-info.java pkga1/ A1.java pkga2/ A2.java pkga3/ A3.java pkgainternal/ InternalA.java modb/ module-info.java pkgb/ B.java modc/ module-info.java pkgc/ C.java modmain/ module-info.java pkgmain/ Main.java
  8. Copyright © Accso – Accelerated Solutions GmbH 16 moda/ module-info.java

    pkga1/ A1.java pkga2/ A2.java pkga3/ A3.java pkgainternal/ InternalA.java modb/ module-info.java pkgb/ B.java modc/ module-info.java pkgc/ C.java modmain/ module-info.java pkgmain/ Main.java Modul-Definition eines Moduls liegt in Datei module-info.java im obersten Modul-Sourcenverzeichnis. • mit allen die Abhängigkeiten zu anderen Modulen • mit der Liste der zugreifbaren Packages Wird kompiliert zu .class-File! Wird mit in das JAR-File paketiert. Beispiel: Vier Module moda, modb, modc, modmain und ihr Sourcenbaum module-info.java
  9. Copyright © Accso – Accelerated Solutions GmbH 18 Abhängigkeitsbeziehungen der

    Module moda, modb, modc, modmain moda/ module-info.java pkga1/ A1.java pkga2/ A2.java pkga3/ A3.java pkgainternal/ InternalA.java modb/ module-info.java pkgb/ B.java modc/ module-info.java pkgc/ C.java modmain/ module-info.java pkgmain/ Main.java module-info.java
  10. Copyright © Accso – Accelerated Solutions GmbH 19 module moda

    { // Read-Abhängigkeiten von moda zu modb und modc // (Compiler meckert fehlende Module an!) requires modb; requires transitive modc; // immer dabei: Abhängigkeit zu java.base // (mandated) // requires java.base; // optionale Abhängigkeit, nur zur Compilezeit // requires static modx; } moda/ module-info.java pkga1/ A1.java pkga2/ A2.java pkga3/ A3.java pkgainternal/ InternalA.java modb/ module-info.java pkgb/ B.java modc/ module-info.java pkgc/ C.java modmain/ module-info.java pkgmain/ Main.java module-info.java moda/module-info.java
  11. Copyright © Accso – Accelerated Solutions GmbH 20 requires transitive

    für transitive Abhängigkeiten module moda { requires modb; requires transitive modc; ...
  12. Copyright © Accso – Accelerated Solutions GmbH 22 Beispiel Schnittstelle

    java.sql.Driver Implementierung in Modul java.sql im MySQL-Driver Dynamische Bindung beim Start über ServiceLoader, also keine statische Auflösung über Modul-Namen wie bei Requires! Dynamische Bindung von Interface und Implementierung module java.sql { … // Definiert Schnittstelle uses java.sql.Driver; // ... und exportiert sie auch exports java.sql; } module com.mysql.jdbc { requires java.sql; … // Implementiert Schnittstelle provides java.sql.Driver with com.mysql.jdbc.Driver; }
  13. Copyright © Accso – Accelerated Solutions GmbH 24 Zugriffsschutz für

    Modul moda moda/ module-info.java pkga1/ A1.java pkga2/ A2.java pkga3/ A3.java pkgainternal/ InternalA.java modb/ module-info.java pkgb/ B.java modc/ module-info.java pkgc/ C.java modmain/ module-info.java pkgmain/ Main.java module-info.java
  14. Copyright © Accso – Accelerated Solutions GmbH 25 module moda

    { // Read-Abhängigkeiten von moda zu modb und modc // (Compiler meckert fehlende Module an!) requires modb; requires transitive modc; // Exports von Packages von moda // (Compiler meckert fehlende Packages an!) exports pkga1; exports pkga2 to modmain; // nur an modmain opens pkga3; // nur zur Laufzeit // für Reflection } moda/ module-info.java pkga1/ A1.java pkga2/ A2.java pkga3/ A3.java pkgainternal/ InternalA.java modb/ module-info.java pkgb/ B.java modc/ module-info.java pkgc/ C.java modmain/ module-info.java pkgmain/ Main.java module-info.java modmain moda/module-info.java
  15. Copyright © Accso – Accelerated Solutions GmbH 26 package pkga1;

    import pkgb.B; import pkgc.C; // Code in Java-Klassen ändert sich nicht! public class A1 { public String doIt() { return "from A1, " + new B().doIt(); } public C getMyC() { return new C(); } } moda/pkga1.A1.java moda/ module-info.java pkga1/ A1.java pkga2/ A2.java pkga3/ A3.java pkgainternal/ InternalA.java modb/ module-info.java pkgb/ B.java modc/ module-info.java pkgc/ C.java modmain/ module-info.java pkgmain/ Main.java A1.java modmain
  16. Copyright © Accso – Accelerated Solutions GmbH 27 modmain/pkgmain.Main.java moda/

    module-info.java pkga1/ A1.java pkga2/ A2.java pkga3/ A3.java pkgainternal/ InternalA.java modb/ module-info.java pkgb/ B.java modc/ module-info.java pkgc/ C.java modmain/ module-info.java pkgmain/ Main.java Main.java modmain public class Main { public static void main(String[] args) throws Exception { // access to pkga1 (exported from moda) pkga1.A1 mya1 = new pkga1.A1(); System.out.println("A1: " + mya1.doIt()); Object myc1 = mya1.getMyC(); System.out.println("from A1: getMyC()=" + myc1); pkgc.C myc2 = mya1.getMyC(); System.out.println("from A1: getMyC()=" + myc2); // access to pkga2 (exported from moda only to modmain) pkga2.A2 mya2 = new pkga2.A2(); System.out.println("A2: " + mya2.doIt()); ...
  17. Copyright © Accso – Accelerated Solutions GmbH 28 public class

    Main { public static void main(String[] args) throws Exception { ... // access to pkga3 (opens from moda) // does not compile, pkga3 only via reflection // pkga3.A3 mya3 = new A3(); Class<?> myA3Class = Class.forName("pkga3.A3"); Constructor<?> con = myA3Class.getDeclaredConstructor(); con.setAccessible(true); // accessible because of opens Object myA3 = con.newInstance(); Method m = myA3.getClass().getMethod("doIt"); m.setAccessible(true); System.out.println("A3: " + m.invoke(myA3)); // does not compile, pkgainternal not exported // pkgainternal.InternalA myinternalA = // new pkgainternal.InternalA(); } modmain/pkgmain.Main.java moda/ module-info.java pkga1/ A1.java pkga2/ A2.java pkga3/ A3.java pkgainternal/ InternalA.java modb/ module-info.java pkgb/ B.java modc/ module-info.java pkgc/ C.java modmain/ module-info.java pkgmain/ Main.java modmain Main.java
  18. Copyright © Accso – Accelerated Solutions GmbH 29 Wie steht‘s

    um Reflection? (und um Serialisierung, Dependency-Injection, Bytecode-Enhancement etc.) Zur Erinnerung 1. Check der Readability 2. Check der Accessibility 3. Check von public,protected,<package>,private Alle Checks auch bei Reflection! Convenience bei Reflection: read-Beziehung ist immer vorhanden. Aber Accessibility-Checks greifen auch „scharf“ bei Reflection: Klassen in nicht exportierten Packages sind also nicht zugreifbar. • Gilt für newInstance, getField, getMethod, … • Gilt auch für setAccessible(true)
  19. Copyright © Accso – Accelerated Solutions GmbH 30 opens öffnet

    für „Deep Reflection“ mit setAccessible(true) Shortcut „open module“ öffnet alle Packages des Moduls mit „opens“ opens öffnet ein Package nur zur Laufzeit Compile-Zeit Reflection (Shallow) Reflection (Deep) exports pkg erlaubt erlaubt nicht erlaubt opens pkg nicht erlaubt erlaubt erlaubt exports pkg und opens pkg erlaubt erlaubt erlaubt
  20. Copyright © Accso – Accelerated Solutions GmbH 31 Letztlich geht‘s

    immer um Typen-Sichtbarkeit: Interfaces exports pkga inter nal pkga Inte rnal Data Nur Export von IData Instanzen von InternalData behalten ihren Typ auch über Modulgrenze hinaus. public class Factory { public IData createData() { return new InternalData(); } … public class Caller { … IData myData = new Factory().createData(); … I Data Fact ory Call er mod main moda pkgmain
  21. Copyright © Accso – Accelerated Solutions GmbH 32 Letztlich geht‘s

    immer um Typen-Sichtbarkeit: Ableitung exports pkga inter nal pkga Inte rnal Data Nur Export von Data Instanzen von InternalData behalten ihren Typ auch über Modulgrenze hinaus. public class Factory { public Data createData() { return new InternalData(); } … public class Caller { … Data myData = new Factory().createData(); … Data Fact ory Call er moda mod main pkgmain
  22. Copyright © Accso – Accelerated Solutions GmbH 33 Letztlich geht‘s

    immer um Typen-Sichtbarkeit: Ableitung exports pkga inter nal pkga Inte rnal Data Caller kann nur Methoden von Data aufrufen, es werden aber die Implementierungen von InternalData benutzt. public class Factory { public Data createData() { return new InternalData(); } … public class Caller { … Data myData = new Factory().createData(); … Data Fact ory Call er moda mod main pkgmain
  23. Copyright © Accso – Accelerated Solutions GmbH 34 pkga inter

    nal pkga Letztlich geht‘s immer um Typen-Sichtbarkeit: Exceptions Interne Exceptions können nach außen geworfen werden. Caller kann nur Oberklassen fangen. public class A { public void doIt() throws InternalException { ... } public class Caller { … try { new A().doIt(); } catch(Exception ex) {...} catch(RuntimeException rex) {…} … Call er moda Inter nal Excep tion Inter nalRun timeExc eption exports A mod main pkgmain
  24. Copyright © Accso – Accelerated Solutions GmbH 35 Zugriff auf

    eine Resource in einem anderen Modul moda: Kein Zugriff erlaubt? Stream ist null , keine IllegalAccessException Der Zugriff ist immer auch ohne opens möglich auf: • Resources im "unnamed package" • Resources, deren Verzeichnis sich nicht auf einen gültigen Packagenamen abbilden lässt (z.B. META-INF/MANIFEST.MF) Resource wird über ihr Verzeichnis geschützt, wenn sich dieses auf einen Package-Namen abbilden lässt. Das Package muss mit opens (nicht exports!) geöffnet sein. Der Zugriff auf Resources anderer Module ist geschützt! A.class.getModule().getResourceAsStream("/foo/bar.properties")
  25. Copyright © Accso – Accelerated Solutions GmbH 37 Wenn Exports

    & Reads der module-info nicht reichen…? Neue Read-Beziehung vonnach Export/Open weiterer Packages Kommandozeile javac, java oder @file programmatisch --add-reads java.lang. Module.addReads() --add-exports --add-opens Auch in JAR-Manifest möglich! java.lang. Module.addExports() Module.addOpens() Vorsicht - Caller-sensitiv: Aufruf nur im eigenen Modul möglich!
  26. Copyright © Accso – Accelerated Solutions GmbH 39 Blackbox-Test testet

    nur öffentliche Schnittstelle von moda. Neues Modul braucht also keinen Zugriff auf interne Klassen. Blackbox-Test eines Moduls moda moda read exports pkga internal pkga $ java --module-path mlib\;amlib --add-modules modtest.blackbox -m junit/org.junit.runner.JUnitCore pkgblacktest.BlackBoxTest junit read modtest. blackbox pkg black test
  27. Copyright © Accso – Accelerated Solutions GmbH 40 Vier Varianten

    für Whitebox-Tests eines Moduls moda Ein Whitebox-Test benötigt zum Test interne Klassen von moda aus dem Package pkgainternal. moda pkga internal pkga Unschön Ein Patch des JAR-Files moda.jar mit passender module-info.class ist i.d.R. keine Alternative. Funktioniert z.B. nicht bei Checksummen! exports
  28. Copyright © Accso – Accelerated Solutions GmbH 41 1. Separates

    Test-Modul modtest.whitebox Wie erhält es Zugriff auf die internen Packages von moda? Whitebox-Test eines Moduls moda : Varianten 1a, b Statische Abhängigkeit zu Testcode Pflege der Skripte?! module moda { exports pkga; exports pkgainternal to modtest.whitebox; } a) Mit exports to der zu testenden Packages an modtest.whitebox $ javac --add-exports moda/pkgainternal=modtest.whitebox $ java --add-exports moda/pkgainternal=modtest.whitebox b) Dynamischer Export der zu testenden Packages mit --add-exports
  29. Copyright © Accso – Accelerated Solutions GmbH 42 2. Das

    Modul moda enthält auch die Testklassen. Aber wo verwaltet man diese? Whitebox-Test eines Moduls moda : Varianten 2a, b Testcode wird mit paketiert und deployed a) Testklassen sind Teil von moda. Testklassen können damit alle zu testenden Klassen aus moda sehen. b) Testklassen werden getrennt abgelegt. Zu Compile-Zeit und zur Test-Laufzeit werden sie dem Modul moda hinzugefügt („Patchen“).
  30. Copyright © Accso – Accelerated Solutions GmbH 43 Whitebox-Test Variante

    2b: moda beim Compile patchen moda pkga internal pkga $ javac --patch-module moda=src --add-reads moda=junit -d patches/moda ... src/modtest.whitebox/pkga/WhiteBoxTest.java junit pkga internal …Test
  31. Copyright © Accso – Accelerated Solutions GmbH 44 moda pkga

    internal pkga pkga internal …Test Whitebox-Test Variante 2b: moda bei Test-Start patchen $ java --patch-module moda=patches/moda --add-reads moda=junit ... -m junit/org.junit.runner.JUnitCore pkga.WhiteBoxTest junit
  32. Copyright © Accso – Accelerated Solutions GmbH 46 Observable Modules

    System-Module-Path Observable Modules: „Was da ist“ java. base Module-Path modmain Alle Module auf dem Module-Path zusammen mit den System-Modulen bilden das „Universum“ der Observable Modules.
  33. Copyright © Accso – Accelerated Solutions GmbH 47 Die Configuration

    ist die transitive Hülle aller Abhängigkeiten aller Root-Module der Observable Modules. Root-Module ist hier modmain Observable Modules System-Module-Path Configuration: „Was wirklich geladen wird“ Module-Path modmain java. base $ java --module-path mlib -m modmain/pkgmain.Main modmain java. base
  34. Copyright © Accso – Accelerated Solutions GmbH 48 Observable Modules

    System-Module-Path Configuration: Weitere Module dazunehmen Module-Path modmain java. base modmain java. base modx Weitere Root-Module werden Configuration mitgegeben über --add-modules $ java --module-path mlib --add-modules mlib/modx.jar -m modmain/pkgmain.Main modx $ java --module-path mlib --add-modules ALL-MODULE-PATH -m modmain/pkgmain.Main
  35. Copyright © Accso – Accelerated Solutions GmbH 49 Observable Modules

    System-Module-Path Configuration: Alle Module aus Module-Path dazunehmen Module-Path modmain java. base modmain java. base modx Shortcut für „alle Module aus MP“ dazunehmen über ALL-MODULE-PATH $ java --module-path mlib --add-modules ALL-MODULE-PATH -m modmain/pkgmain.Main
  36. Copyright © Accso – Accelerated Solutions GmbH 52 Ein Named

    Module darf keine Klassen im Unnamed Package enthalten. Resources sind dagegen im Unnamed Package weiterhin erlaubt. Klassen im Unnamed Package nicht mehr erlaubt src\moda\MyClassInTheUnnamedPackage.java:2: error: unnamed package is not allowed in named modules public class MyClassInTheUnnamedPackage { ^ 1 error Compile- Fehler
  37. Copyright © Accso – Accelerated Solutions GmbH 53 Compile- Fehler

    Laufzeit- Fehler beim Start Ein „Split“ eines Package auf mehrere Module ist nicht erlaubt! Gilt auch, wenn das Package nicht exportiert ist!! Selbst dann, wenn es keine Klassen-Duplikate in den beiden Modulen gibt!!! Split Package: Module müssen disjunkte Packages haben. Ausnahme: Gilt nicht für The Unnamed Module. src\modmainfoo\module-info.java:1: error: module modmainfoo reads package pkgfoo from both modsplitfoo1 and modsplitfoo2 module modmainfoo { ^ 1 error Error occurred during initialization of boot layer java.lang.LayerInstantiationException: Package pkgbar in both module modsplitbar1 and module modsplitbar2 Gilt nur für Module in einer gemeinsamen Configuration (nur auf Module-Path OK).
  38. Copyright © Accso – Accelerated Solutions GmbH 54 jdeps zeigt

    die Verwendung von JDK-internen Klassen: Seit Java 8: Neue offizielle APIs ersetzen unsupportete APIs. Beispiel: sun.misc.BASE64Encoder  java.util.Base64.Encoder Andere APIs werden schrittweise ersetzt, später nicht mehr zugänglich sein. Details siehe JEP 260: http://openjdk.java.net/jeps/260 JDK-interne APIs sind geschützt, nicht mehr zugreifbar! $ jdeps --jdk-internals ./classes pkgmain.Main -> jdk.internal.misc.SharedSecrets JDK internal API (java.base) Warning: JDK internal APIs are unsupported and private to JDK implementation that are subject to be removed or changed incompatibly and could break your application. Please modify your code to eliminate dependence on any JDK internal APIs. For the most recent update on JDK internal API replacements, please check: https://wiki.openjdk.java.net/display/JDK8/Java+Dependency+Analysis+Tool
  39. Copyright © Accso – Accelerated Solutions GmbH 55 Kill-Switch erlaubt

    einen illegalen Zugriff: permit entspricht einem opens auf alle JDK-internen Packages, aber nur auf die Packages, die es bereits in Java 8 gab! Nur in Java 9 ist permit der Default – nur bis Release 18.3! Der große Kill-Switch --illegal-access $ java --add-opens=java.base/sun.io=ALL-UNNAMED ... $ java --illegal-access=permit|warn|deny ... Einige prominente Frameworks sind noch nicht auf Java 9 umgestellt. Hauptproblem: Verwendung JDK-interner Klassen per Reflection. Lösung: --add-opens öffnet benötigte Packages für Classpath. • Nachteil: --add-opens muss in allen run-Skripten gesetzt werden! • Bricht zahlreichen existierenden Code!
  40. Copyright © Accso – Accelerated Solutions GmbH 58 Vorschlag: Release

    alle 6 Monate. Wechsel zu „time-based release train“ Nächstes Release bereits im März 2018 als „18.3“ http://openjdk.java.net/projects/jdk/18.3/ Releases im März & September mit fertigen neuen Features Dazu vier weitere Releases im Jahr mit Security- und Bugfixes Alle 3 Jahre Releases mit LTS (Long-Term-Support), evtl. ab „18.9“ https://mreinhold.org/blog/forward-faster #javatrain http://mail.openjdk.java.net/pipermail/discuss/2017- September/thread.html#4281 Warum umsteigen? Neue Release-Policy nach Java 9!
  41. Copyright © Accso – Accelerated Solutions GmbH 72 Compile Run

    Neue Argumente für Compiler und Launcher $ JAVA_HOME/bin/java --module-path mlib --module modmain/pkgmain.Main $ JAVA_HOME/bin/javac -d mods --module-path mlib --module-source-path src $(find src -name "*.java")
  42. Copyright © Accso – Accelerated Solutions GmbH 73 Modul auf

    dem MP Modul in einem JAR Modul in einer JMOD-Datei Aus einer module- info.class Wie kann man Informationen zu einem Modul ausgeben? $ jar --file mlib/modmain.jar –-describe-module $ jdeps --module-path mlib mlib/modmain.jar $ jmod describe $JAVA_HOME/jmods/java.base.jmod $ javap -verbose module-info.class $ java --module-path mlib --describe-module modmain
  43. Copyright © Accso – Accelerated Solutions GmbH 74 Wie generiert

    man module-info für „normales JAR“? $ jdeps --generate-module-info ./gensrc -s amlib/*.jar module junit { // Modul-Name "junit" automatisch aus junit-4.12.jar requires java.management; requires transitive hamcrest.core; exports junit.extensions; // es werden *alle* Packages exportiert exports junit.framework; exports junit.runner; exports junit.textui; exports org.junit; ... exports org.junit.runners.model; exports org.junit.runners.parameterized; exports org.junit.validator; } z.B. für JAR-File junit-4.12.jar
  44. Copyright © Accso – Accelerated Solutions GmbH 75 open module

    junit { // Modul-Name "junit" automatisch aus junit-4.12.jar requires java.management; requires transitive hamcrest.core; } $ jdeps --generate-open-module ./gensrc -s amlib/*.jar Wie generiert man module-info für „normales JAR“? z.B. für JAR-File junit-4.12.jar
  45. Copyright © Accso – Accelerated Solutions GmbH 76 Observable Modules

    Configuration Debugging Debugger gibt Modul aus Stacktrace gibt Modul mit aus Wie erhalte ich Informationen zur Laufzeit? $ java –Xdiag:resolver ... $ java –Xlog:module=debug|trace ... $ java --module-path ./mlib --list-modules ... über Class.getModule() pkgb.MyException: MyException's message at modb/pkgb.B.doItThrowException(B.java:13) at modmain/pkgmain.Main.main(Main.java:18) $ java --module-path ./mlib --show-module-resolution
  46. Copyright © Accso – Accelerated Solutions GmbH 77 Unser Tool

    „DepVis“ zur Visualisierung von Modul-Graphen Ideen: requires-n-transitive, Filter auf einzelne Beziehungen, Packages, Hashes, nur Module der Configuration, mehr Konfiguration mit Farben & Co … https://github.com/accso/java9-jigsaw-depvis Basiert auf GraphViz http://www.graphviz.org/ mit Java-API https://github.com/kohsuke/graphviz-api Visualisierung und Textausgabe von Modulen auf Module-Path und im System mit Wildcard – Black-&Whitelisting Explicit, Automatic, Open requires (auch 1-transitive, static, mandated), exports-to, opens-to Concealed Packages uses und provides
  47. Copyright © Accso – Accelerated Solutions GmbH 79 Module java.desktop@9

    (automatic: false) requires java.base [MANDATED] requires java.datatransfer [TRANSITIVE] requires java.prefs requires java.xml [TRANSITIVE] exports java.applet exports java.awt exports java.awt.color exports java.awt.desktop exports java.awt.dnd exports java.awt.event exports java.awt.font exports java.awt.geom exports java.awt.im exports java.awt.im.spi ... exports java.awt.dnd.peer to [javafx.swing] exports sun.awt to [oracle.desktop, jdk.accessibility, javafx.swing] exports sun.awt.dnd to [javafx.swing] exports sun.awt.image to [javafx.swing] exports sun.font.lookup to [javafx.graphics] exports sun.java2d to [javafx.swing, oracle.desktop] exports sun.print to [javafx.graphics] System-Modul java.desktop 4 requires 50 exports, 8 exports-to 0 opens, 2 opens-to 12 uses, 17 provides 74 Concealed Packages
  48. Copyright © Accso – Accelerated Solutions GmbH 80 Module java.base@9

    exports java.io exports java.lang.... exports java.math exports java.net.... exports java.nio.... exports java.security.... exports java.text.... exports java.time.... exports java.util.... exports javax.crypto.... exports javax.net.... exports javax.security.... exports com.sun.security.ntlm to [java.security.sasl] exports jdk.internal to [jdk.jfr] exports jdk.internal.jimage to [jdk.jlink] exports jdk.internal.jimage.decompressor to [jdk.jlink] exports jdk.internal.jmod to [jdk.jlink, jdk.compiler] exports jdk.internal.loader to [java.instrument, java.logging] exports jdk.internal.logger to [java.logging] ... exports sun.net to [jdk.incubator.httpclient] exports sun.net.dns to [jdk.naming.dns, java.security.jgss] exports sun.net.ext to [jdk.net] ... exports sun.util.resources to [jdk.localedata] System-Modul java.base keine requires 51 exports, 57 exports-to 0 opens, 0 opens-to 34 uses, 1 provides 53 Concealed Packages, davon 49 mit *sun*, Rest ist jdk.internal*
  49. Copyright © Accso – Accelerated Solutions GmbH 82 Eclipse 4.7.1a

    Oxygen.1 von Oktober 2017 unterstützt Java 9 (alte Eclipse-Versionen mit Beta-Plugin besser meiden!) • Eclipse startet mit Java 9 • Java 9 als JRE nutzbar • Code-Completion für module-info für requires, exports, opens … • Launch und Debug kann Module-Path Noch buggy oder fehlt: Fehler bei Automatic Modules, JUnit-Dialoge ohne MP, Unnamed-Package-Compilefehler, keine Optionen für J9-Compiler einstellbar (z.B. --add-exports) Entwicklungstools: Eclipse
  50. Copyright © Accso – Accelerated Solutions GmbH 83 ein Eclipse-

    Projekt == ein Modul Aktuell(?) muss Modellierung der Modul- Beziehungen redundant in Eclipse- Projekten erfolgen
  51. Copyright © Accso – Accelerated Solutions GmbH 84 Strukturen, pom

    unverändert test-compile unterstützt Blackbox- und Whitebox-Tests. test noch mit Classpath. Abhängigkeiten müssen redundant in der pom und in der module-info modelliert werden. Build-Tools: Maven mit Java-9-Support … <dependency> <groupId>de.accso.jigsaw</groupId> <artifactId>moda</artifactId> <version>0.0.1-SNAPSHOT</version> </dependency> module modmain { requires moda; }
  52. Copyright © Accso – Accelerated Solutions GmbH 86 Was ist

    „Java9 Ready?“ https://wiki.openjdk.java.net/display/quality/Quality+Outreach
  53. Copyright © Accso – Accelerated Solutions GmbH 115 Drastische Semantikänderung:

    public != accessible Erster Accessibility-Level ist nun das „Package“. (Warum eigentlich?) Zugriffsschutz ist sehr restriktiv. Opt-in oder Opt-out? Leider keine Wildcards bei Exports-Package! Ein Modul hat keine (echten) Versionen - nur informell module-info wird zu .class-File kompiliert. Ist aber doch gar keine Klasse. Warum nicht MANIFEST.MF? Oder wenigstens Human-Readable-Format? Abhängigkeitsmodell ist sehr statisch über Namen. Kein Alias für ein Modul möglich (außer --patch-module) Module sind nicht gruppierbar. Keine Hierarchie möglich (vgl. parent.pom) Warum keine Scopes wie „Test“ und „Runtime“ (vgl. Maven)? Kritik …
  54. Copyright © Accso – Accelerated Solutions GmbH 116 Der richtige

    Schritt zur echter Komponentenorientierung! Jigsaw und Java 9 sind sehr stabil. Allerdings sehr viel Dynamik: Implementierungen (und auch Konzepte, gerade zu Reflection) wurden bis zuletzt geändert. Kill-Switch als Antwort auf JCP-Ablehnung im April 2017. Aggregator-Module über requires transitive Migration ist gut machbar, aber wird mühsam! • Modul-Kategorien: „wo kommt was her?“ ist nicht trivial! • MP & CP: Bekommen wir das jemals richtig aussortiert? … und Lob!
  55. Copyright © Accso – Accelerated Solutions GmbH 119 Homepage Project

    Jigsaw OpenJDK: JDK 9 Oracle: JDK 9 Documentation Jigsaw-Issues Specification (2015) State of the Module System (2016) Quickstart Guide JSR376 JEPs 200 „The modular JDK“ 220 „Modular Runtime Images“ 260 „Encapsulate Most Internal APIs“ Mailinglisten jigsaw-dev, jdk9-dev, jpms-spec-comments, jpms-spec-experts, jpms-spec-observers 261 „Module System“ 275 „Modular Java App. Packaging“ 282 „jlink: The Java Linker“ http://mail.openjdk.java.net/mailman/listinfo http://openjdk.java.net/projects/jigsaw/ http://openjdk.java.net/projects/jdk9/ https://docs.oracle.com/javase/9/ http://openjdk.java.net/projects/jigsaw/spec/issues/ http://openjdk.java.net/projects/jigsaw/spec/reqs/ http://openjdk.java.net/projects/jigsaw/spec/sotms/ http://openjdk.java.net/projects/jigsaw/quick-start https://www.jcp.org/en/jsr/detail?id=376 http://openjdk.java.net/jeps/<NR> Zum Nachlesen
  56. Copyright © Accso – Accelerated Solutions GmbH 120 https://github.com/accso/java9-jigsaw-examples/ Läuft

    mit Java Release-Build b181 und 9.0.1 Bash-Skripte für Compile, Run, Test (in Windows z.B. mit Babun nutzbar) Projekte für Eclipse 4.7.1a Unsere 32 Beispiele zeigen alles Wissenswerte zu Jigsaw zu Requires, Exports, Exports-To, Requires-Static, Requires-Transitive, Blackbox-Test, Whitebox-Test, Uses, Provides, Maven-Integration, Opens, Open Module, Manifest-Optionen, versteckte Main-Klasse, Automatic Modules, Reflection, Resolved Modules (Configuration), Naming von Modulen, Unnamed Module (Classpath), Layer, Javadoc, Annotations, jlink etc. pp. usw. usf. Unsere Jigsaw-Beispiele stehen auf Github
  57. Copyright © Accso – Accelerated Solutions GmbH 124 Copyright ©

    Accso GmbH http://accso.de/java/ JavaSPEKTRUM- Sonderdruck zu Java 9 / Jigsaw oder heute hier am Accso-Stand
  58. Copyright © Accso – Accelerated Solutions GmbH 125 125 Copyright

    © Accso GmbH 125 Accso – Accelerated Solutions GmbH T | +49 6151 13029-0 E | [email protected] @ | www.accso.de Berliner Allee 58 | 64295 Darmstadt Moltkestraße 131a | 50674 Köln Balanstraße 55 | 81541 München https://de.slideshare.net/lemmi @accso @lemmi111171 @krschaal https://github.com/accso/java9-jigsaw-examples/ https://github.com/accso/java9-jigsaw-depvis/