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

Modularity Patterns mit Java9/Jigsaw

Modularity Patterns mit Java9/Jigsaw

Martin Lehmann, Kristine Schaal: „Modularity Patterns mit Java9/Jigsaw“. OOP Code-Days 2018, München, 07.02.2018

Martin Lehmann

February 07, 2018
Tweet

More Decks by Martin Lehmann

Other Decks in Programming

Transcript

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

    v.3.12 Modularity-Patterns mit Java 9 / Jigsaw MARTIN LEHMANN, DR. KRISTINE SCHAAL | CODE DAYS 2018 Code Days 2018, Februar 2018 @mrtnlhmnn @krschaal
  2. Copyright © Accso – Accelerated Solutions GmbH 2 Mit Java

    9 kam im September 2017 (endlich!) das lange angekündigte und lang ersehnte 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. Komponentenbasierte Software ist nichts Neues. Mit Java 9 steht nach über 20 Jahren Java-Entwicklung nun direkt ein natives Sprachmittel zur Verfügung, um Komponenten zu definieren und in der Architektur zu verankern. Was bisher nur mit Tools wie Maven oder Ivy bzw. statische Code-Analyse möglich war, ist nun direkt als Sprachfeature verfügbar. Wir betrachten verschiedene bekannte Modularity-Design-Patterns und zeigen, wie man diese mit Jigsaw umsetzen kann, darunter Patterns zu Architektur- und Komponentenschnitt, Patterns zu Abhängigkeiten, Patterns zu Test, Patterns zu Erweiterbarkeit und zur Evolution / Migration. • Wie unterscheiden sich die Patterns zu Compile- bzw. zur Laufzeit? • Welche Patterns werden gut unterstützt, welche erfordern zusätzliche Klimmzüge oder gar eigene Erweiterungen? • Welche Features kann Jigsaw in Java 9 noch nicht (Beispiel: Module-Versionierung)? Abstract – OOP Code Days 2018 http://www.code-days.de/programm/programm-details/97/modularity-patterns-mit-java-9-jigsaw/
  3. Copyright © Accso – Accelerated Solutions GmbH 3 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] @mrtnlhmnn 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 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 5 Project Jigsaw

    in Java 9: 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.4 vom 16. Januar 2018 Enthalten: JEP 261, 200, 201, 220, 260, 282 mit Modulsystem, modularisiertem JDK und der Kapselung interner APIs
  5. Copyright © Accso – Accelerated Solutions GmbH 7 Kirk Knoernschild

    Java Application Architecture: Modularity Patterns with Examples Using OSGi Series: Robert C. Martin Series Paperback: 384 pages Publisher: Prentice Hall; 1 edition March 25, 2012 ISBN-10: 0321247132 ISBN-13: 978-0321247131 http://www.kirkk.com/modularity/ https://mreinhold.org/blog/jigsaw-complete
  6. Copyright © Accso – Accelerated Solutions GmbH 8 Base Patterns

    Manage Relationships – Design module relationships Module Reuse – Emphasize reusability at the module level Cohesive Modules – Module behavior should serve a singular purpose Dependency Patterns Acyclic Relationships – Module relationships must be acyclic Levelize Modules – Module relationships should be levelized Physical Layers – Module relationships should not violate the conceptual layers Container Independence – Modules should be independent of the runtime container Independent Deployment – Modules should be independently deployable units Usability Patterns Published Interface – Make a module’s published interface well known External Configuration – Modules should be externally configurable Default Implementation – Provide modules with a default implementation Module Facade – Facade as a coarse-grained entry point to another module’s fine-grained underlying implementation Extensibility Patterns Abstract Modules – Depend upon the abstract elements of a module Implementation Factory – Use factories to create a module’s implementation classes Separate Abstractions – Place abstractions and the classes that implement them in separate modules Utility Patterns Collocate Exceptions – Exceptions should be close to the classes that throw them Levelized Build – Execute the build in accordance with module levelization Test Module – Each module should have a corresponding test module that validates it’s behavior and illustrates it’s usage Pattern Catalog http://www.kirkk.com/modularity/ pattern-catalog/
  7. Copyright © Accso – Accelerated Solutions GmbH 9 Base Pattern

    Manage Relationships Design module relationships
  8. Copyright © Accso – Accelerated Solutions GmbH 10 Base Pattern

    Manage Relationships Pattern Komponenten = eigenständige, wiederverwendbare „Software- Bausteine“ Wohldefinierte Schnittstellen Eingehende Schnittstellen Ausgehende Schnittstellen Der Grad der Abhängigkeiten bestimmt die Komplexität einer Anwendung maßgeblich. Vorteile Komponenten brechen den Monolithen auf. Auswirkungen von Änderungen sind klar nachvollziehbar. Es wird nur geladen, was wirklich benötigt wird. Es wird (zunächst) nur geladen, was wirklich modelliert wurde. Nachteile
  9. Copyright © Accso – Accelerated Solutions GmbH 11 Module :=

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

    Manage Relationships Pattern Komponenten = eigenständige, wiederverwendbare „Software- Bausteine“ Wohldefinierte Schnittstellen Eingehende Schnittstellen Ausgehende Schnittstellen Der Grad der Abhängigkeiten bestimmt die Komplexität einer Anwendung maßgeblich. … mit Jigsaw Module-Deskriptor Module-Name Abhängigkeiten Zugriffsschutz Keine weiteren Syntax- oder Sprachkonstrukte!
  11. Copyright © Accso – Accelerated Solutions GmbH 13 Base Pattern

    Manage Relationships Pattern Komponenten = eigenständige, wiederverwendbare „Software- Bausteine“ Wohldefinierte Schnittstellen Eingehende Schnittstellen Ausgehende Schnittstellen Der Grad der Abhängigkeiten bestimmt die Komplexität einer Anwendung maßgeblich. … mit Jigsaw Beziehungen zwischen Modules Keine Scopes (wie in Maven) Statische Bindung über Namen Dynamische Bindung zur Startzeit Nutzung Statische Aufrufe Dynamisch per Reflection
  12. Copyright © Accso – Accelerated Solutions GmbH 14 Ein Module

    kann ein anderes Module nur benutzen, wenn es eine „read“-Beziehung zu ihm hat (aka: „requires“). Manage Relationships Jigsaw: Explizite Abhängigkeiten modb module moda { // read auf modb requires modb; } read modc moda/module-info.java Das Module moda hat eine read-Beziehung zu Module modb, jedoch keine zu modc  moda kann nur auf modb zugreifen. moda
  13. Copyright © Accso – Accelerated Solutions GmbH 15 Base Pattern

    Manage Relationships Transitive Abhängigkeiten? Versionierung? Gruppierungen? Hierarchien? Remote oder lokal? Checks zu Compile/Build-Time? Checks zu Runtime (Start/lazy)? Vertiefte Konzepte … mit Jigsaw Ja! Nein (nur informell)! Nicht einfach*! Nicht einfach*! Nur lokal, keine Verteilung! Ja! Ja! *) Zumindest nicht wie in Maven mit group-id. Nicht-triviale Lösungen über Aggregrator-Modules und ModuleLayer.
  14. Copyright © Accso – Accelerated Solutions GmbH 16 Jigsaw: Module-Graphen

    z.B. mit DepVis https://github.com/accso/ java9-jigsaw-depvis Basiert auf GraphViz http://www.graphviz.org/ mit Java-API https://github.com/kohsuke/graphviz-api
  15. Copyright © Accso – Accelerated Solutions GmbH 17 Dependency Pattern

    Acyclic Relationships Module relationships must be acyclic
  16. Copyright © Accso – Accelerated Solutions GmbH 22 Usability Pattern

    Published Interface Make a module’s published interface well known
  17. Copyright © Accso – Accelerated Solutions GmbH 23 Usability Pattern

    Published Interface Pattern Komponente definiert ihre öffentliche Schnittstelle. Nutzer verwenden die Komponente nur über diese Schnittstelle. Von außen ist kein Zugriff auf die Implementierung möglich.
  18. Copyright © Accso – Accelerated Solutions GmbH 24 Usability Pattern

    Published Interface Pattern Komponente definiert ihre öffentliche Schnittstelle. Nutzer verwenden die Komponente nur über diese Schnittstelle. Von außen ist kein Zugriff auf die Implementierung möglich. Vorteile Erfordert explizite Definition von Komponenten-Grenzen Dokumentation Änderung der gekapselten Implementierung hat keine Auswirkung auf Nutzer.
  19. Copyright © Accso – Accelerated Solutions GmbH 25 Usability Pattern

    Published Interface Pattern Komponente definiert ihre öffentliche Schnittstelle. Nutzer verwenden die Komponente nur über diese Schnittstelle. Von außen ist kein Zugriff auf die Implementierung möglich. Nachteile Höhere Komplexität durch Indirektion zum Erzeugen der Implementierung Instabile Schnittstellen Abwärtskompatibilitätsfalle Law of Leaky Abstraction: „All non-trivial abstractions, to some degree, are leaky.” (Joel Spolsky)
  20. Copyright © Accso – Accelerated Solutions GmbH 27 public interface

    MyInterface { public MyData myMethod (String param) throws MyException; } Die Schnittstelle einer Komponente beinhaltet alles, was ein Nutzer braucht, um die Komponente benutzen zu können. Interfaces Factories zum Erzeugen der Implementierung Datentypen Exceptions Was gehört zur Schnittstelle einer Komponente?
  21. Copyright © Accso – Accelerated Solutions GmbH 28 Published Interface

    Jigsaw erlaubt exports von Packages Nur exportierte Packages eines Modules sind von außen zugreifbar. module modb { exports pkg.myapi; } read moda pkg. myimpl modb exports modb/module-info.java Export nur auf Package-Ebene! • API- und Implementierungsklassen in verschiedene Packages legen • Oder Implementierung zur API dazulegen – nur als „package-sichtbar“. pkg. myapi
  22. Copyright © Accso – Accelerated Solutions GmbH 30 exports erlaubt

    statische Zugriffe. opens öffnet für „Deep Reflection“ mit setAccessible(true) 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 Published Interface opens öffnet Package zur Laufzeit
  23. Copyright © Accso – Accelerated Solutions GmbH 31 Usability Pattern

    Published Interface Pattern Komponente definiert ihre öffentliche Schnittstelle. Nutzer verwenden die Komponente nur über diese Schnittstelle. Von außen ist kein Zugriff auf die Implementierung möglich. … mit Jigsaw exports erlaubt Zugriff Auf Package-Ebene Keine Wildcards Zugriff per Reflection nur mit exports oder opens Gerichteter Export möglich mit exports to bzw. opens to
  24. Copyright © Accso – Accelerated Solutions GmbH 32 Usability Pattern

    Published Interface … mit Jigsaw Pattern Komponente definiert ihre öffentliche Schnittstelle. Nutzer verwenden die Komponente nur über diese Schnittstelle. Von außen ist kein Zugriff auf die Implementierung möglich. Checks zu Compile-Zeit und zur Laufzeit von 1. neu: Readability (read) 2. neu: Accessibility (exports) 3. Sichtbarkeitsmodifier public, protected, <package>, private Gilt alles auch für System- Module (wie java.base)
  25. Copyright © Accso – Accelerated Solutions GmbH 33 Usability Pattern

    Separate Abstractions Place abstractions and the classes that implement them in separate modules
  26. Copyright © Accso – Accelerated Solutions GmbH 34 Usability Pattern

    Separate Abstractions Pattern Trenne Implementierung von API  in verschiedene Komponenten API-Komponente hat keine Abhängigkeit zu der Implementierung. Auswahl/Konfiguration einer Implementierung erfolgt außerhalb der API-Komponente. Factories nicht enthalten. Vorteile Implementierung kann komplett ausgetauscht werden, erlaubt späte Wahl (zur Laufzeit). Beispiel: Datenbank-Treiber Weitere Indirektionen Mehr Aufwand Höhere Komplexität, Zusammen- spiel schwerer nachvollziehbar Nachteile
  27. Copyright © Accso – Accelerated Solutions GmbH 35 Usability Pattern

    Separate Abstractions auf 3 Ebenen pkg.service IService1 IService2
  28. Copyright © Accso – Accelerated Solutions GmbH 36 Usability Pattern

    Separate Abstractions auf 3 Ebenen pkg.service IService1 IService2 pkg.foobar IFoo IBar
  29. Copyright © Accso – Accelerated Solutions GmbH 37 Usability Pattern

    Separate Abstractions auf 3 Ebenen pkg.service IService1 IService2 pkg.foobar IFoo IBar api
  30. Copyright © Accso – Accelerated Solutions GmbH 38 Usability Pattern

    Separate Abstractions auf 3 Ebenen pkg.service.blue Impl1 Impl2 pkg.foobar.blue FooImpl BarImpl blue.impl
  31. Copyright © Accso – Accelerated Solutions GmbH 39 Usability Pattern

    Separate Abstractions auf 3 Ebenen pkg.service.green OtherImpl 1 OtherImpl 2 pkg.foobar.green FooImpl BarImpl green.impl
  32. Copyright © Accso – Accelerated Solutions GmbH 40 Usability Pattern

    Separate Abstractions auf 3 Ebenen pkg.service.red RedImpl1 RedImpl2 red.impl
  33. Copyright © Accso – Accelerated Solutions GmbH 41 Usability Pattern

    Separate Abstractions auf 3 Ebenen factory client
  34. Copyright © Accso – Accelerated Solutions GmbH 42 Usability Pattern

    Separate Abstractions auf 3 Ebenen factory client Auswahl der Implementierung als „ganze“ Komponente
  35. Copyright © Accso – Accelerated Solutions GmbH 43 Usability Pattern

    Separate Abstractions auf 3 Ebenen factory client Auswahl der Implementierung in „Teilen“ (einmalig oder nach Bedarf)
  36. Copyright © Accso – Accelerated Solutions GmbH 44 Separate Abstractions

    mit Jigsaw-Modules green.impl red.impl blue.impl api read read exports read
  37. Copyright © Accso – Accelerated Solutions GmbH 46 Separate Abstractions

    „Factory-Module“ mit Jigsaw green.impl red.impl blue.impl api factory client
  38. Copyright © Accso – Accelerated Solutions GmbH 47 green.impl red.impl

    blue.impl api factory client Separate Abstractions „Factory-Module“ mit Jigsaw read read read
  39. Copyright © Accso – Accelerated Solutions GmbH 48 green.impl red.impl

    blue.impl api factory client Separate Abstractions „Factory-Module“ mit Jigsaw exports to exports to exports to Factory muss Implementierungsklassen kennen!
  40. Copyright © Accso – Accelerated Solutions GmbH 49 green.impl red.impl

    blue.impl api DI- Framework client Zugriff per Reflection (erfordert „opens“) – z.B. für Spring-Fwk Separate Abstractions „DI-Module“ mit Jigsaw opens to opens to opens to
  41. Copyright © Accso – Accelerated Solutions GmbH 50 Dynamische Bindung

    beim Start über ServiceLoader, also keine statische Auflösung über Module-Namen wie bei requires! Beispiel Schnittstelle java.sql.Driver Implementierung in Module java.sql im MySQL-Driver 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; } Separate Abstractions Dynamische Bindung in Jigsaw
  42. Copyright © Accso – Accelerated Solutions GmbH 52 Usability Pattern

    Module Facade Facade as a coarse-grained entry point to another module’s underlying implementation
  43. Copyright © Accso – Accelerated Solutions GmbH 53 Usability Pattern

    Module Facade Pattern Vgl. GOF-Patterns „Facade“, „Adapter“, „Decorator“ Eine Komponente dient als zentrale Facade zu andere(n) Komponente(n). Abhängigkeit idealerweise nur zur Facade nötig, nicht zu den „dahinter“ liegenden Komponenten Vorteile Kapselt dahinterliegende Details an zentraler Stelle Kapselt Schnittstellen Höhere Lesbarkeit Einfachere Nutzung Erzwingt Reihenfolgen, erlaubt automatische Vor- / Nach-Bearbeitung
  44. Copyright © Accso – Accelerated Solutions GmbH 54 Module Facade

    „Facade-Modules“ mit Jigsaw In „Facade-Modules“ kann man andere APIs kapseln / wrappen.
  45. Copyright © Accso – Accelerated Solutions GmbH 55 Module Facade

    Jigsaw erlaubt transitive Abhängigkeiten module modfacade { requires modx; requires transitive mody; } modfacade/module-info.java In eigenen „Facade-Modules“ kann man andere APIs kapseln / wrappen. Jigsaw ermöglicht aber auch, Abhängigkeiten transitiv weiterzugeben.
  46. Copyright © Accso – Accelerated Solutions GmbH 56 1-transitiv 2-transitiv

    Module Facade Jigsaw erlaubt transitive Abhängigkeiten
  47. Copyright © Accso – Accelerated Solutions GmbH 57 Usability Pattern

    Module Facade Pattern Vgl. GOF-Patterns „Facade“, „Adapter“, „Decorator“ Eine Komponente dient als zentrale Facade zu andere(n) Komponente(n). Abhängigkeit idealerweise nur zur Facade nötig, nicht zu den „dahinter“ liegenden Komponenten … mit Jigsaw requires transitive in module-info reicht Abhängig- keit automatisch weiter Ermöglicht leere Aggregator- Modules Ermöglicht nicht die Kapselung der „dahinter“ liegenden APIs: Im Gegenteil werden diese über Facade-API durchgereicht!
  48. Copyright © Accso – Accelerated Solutions GmbH 58 Utility Pattern

    Test Module Each module should have a corresponding test module that validates it’s behavior …
  49. Copyright © Accso – Accelerated Solutions GmbH 59 Utility Pattern

    Test Module Pattern Zu jeder Komponente eine korrespondierende Testkomponente erstellen. Blackbox-Test testet nur die öffentlichen Schnittstelle. Die Testkomponente hängt nicht von weiteren Komponenten ab (Mocking). Separate Integrationstest- komponenten erstellen Vorteile Komponenten sind unabhängig voneinander testbar, Fehler leichter lokalisierbar Dokumentation der Nutzung der Schnittstelle Nachteile Hoher Aufwand durch Mocks Nachteile
  50. Copyright © Accso – Accelerated Solutions GmbH 60 read pkg

    black test moda. test. black Blackbox-Tests werden in separates Jigsaw-Module ausgelagert. Dieses Testmodule benötigt keinen Zugriff auf interne Klassen. Test Module Blackbox-Tests mit Jigsaw pkga internal exports moda pkga
  51. Copyright © Accso – Accelerated Solutions GmbH 61 Whitebox-Test testet

    interne Klassen von moda aus pkgainternal. Verschiedene Varianten denkbar, z.B. eigenes Module und „exports to“ Besser: Testcode getrennt ablegen und für Compile der Tests und für Testdurchführung in das Module „reinpatchen“. pkga internal pkga internal …Test exports moda pkga Test Module Whitebox-Tests mit Jigsaw
  52. Copyright © Accso – Accelerated Solutions GmbH 68 Dependency Patterns

    Levelize Modules Module relationships should be levelized Physical Layers Module relationships should not violate the conceptual layers Levelized Build Execute the build in accordance with module levelization
  53. Copyright © Accso – Accelerated Solutions GmbH 69 Trennung von

    (technischen) Schichten und (fachlichen) Säulen Säule 2 Säule 3 … Säule 1 Schicht Anwendungskern Schicht Persistenz Schicht Präsentation
  54. Copyright © Accso – Accelerated Solutions GmbH 70 Komponenten sortieren

    sich in diese Schichten/Säulen ein. Säule 2 Säule 3 … Säule 1 Schicht Anwendungskern Schicht Persistenz Schicht Präsentation
  55. Copyright © Accso – Accelerated Solutions GmbH 71 Jigsaw-Modules als

    gerichteter Graph … mit Jigsaw Jigsaw erstellt einen Abhängigkeitsgraph: Modellierung der Abhängig- keiten mit requires Keine zyklischen Abhängigkeiten Dieser Graph sollte auch die Schichten und Säulen abbilden. Eine Unterstützung durch Jigsaw gibt es dafür nicht.
  56. Copyright © Accso – Accelerated Solutions GmbH 76 Kritik Drastische

    Semantikänderung: public != accessible Erster Accessibility-Level ist das „Package“. (Warum eigentlich?) Zugriffsschutz ist sehr restriktiv. Opt-in oder Opt-out? Keine Wildcards! module-info als Java-Datei? Abhängigkeitsmodell ist statisch Keine Alias Keine Versionen, Scopes, Gruppierung, Hierarchie
  57. Copyright © Accso – Accelerated Solutions GmbH 77 Lob Der

    richtige Schritt zur echter Komponentenorientierung! Jigsaw und Java 9 sind schon lange sehr stabil. Allerdings sehr viel Dynamik: Implementierungen & Konzepte wurden bis zuletzt geändert, zum Teil aufgeweicht. Kritik Drastische Semantikänderung: public != accessible Erster Accessibility-Level ist das „Package“. (Warum eigentlich?) Zugriffsschutz ist sehr restriktiv. Opt-in oder Opt-out? Keine Wildcards! module-info als Java-Datei? Abhängigkeitsmodell ist statisch Keine Alias Keine Versionen, Scopes, Gruppierung, Hierarchie
  58. Copyright © Accso – Accelerated Solutions GmbH 80 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> Jigsaw-Dokumentation zum Nachlesen
  59. Copyright © Accso – Accelerated Solutions GmbH 81 http://accso.de/java/ JavaSPEKTRUM-

    Sonderdruck zu Java 9 / Jigsaw oder heute hier zum Mitnehmen heise/iX Sonderheft „Java 2017“ 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
  60. Copyright © Accso – Accelerated Solutions GmbH 83 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
  61. Copyright © Accso – Accelerated Solutions GmbH 87 87 87

    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://speakerdeck.com/mrtnlhmnn @accso @mrtnlhmnn @krschaal https://github.com/accso/java9-jigsaw-examples/ https://github.com/accso/java9-jigsaw-depvis/ http://accso.de/java/