Java-Technologie

aus Wikipedia, der freien Enzyklopädie
Zur Navigation springen Zur Suche springen
Java-Logo
Java Technologies

Die Java-Technik (englisch Java Technology) ist eine ursprünglich von Sun (heute Oracle-Gruppe) entwickelte Sammlung von Spezifikationen, die zum einen die Programmiersprache Java und zum anderen verschiedene Laufzeitumgebungen für Computerprogramme definieren. Diese Computerprogramme werden meistens in Java geschrieben.

Zur Java-Technik gehören die folgenden Bestandteile:

Ziel[Bearbeiten | Quelltext bearbeiten]

Mit der Java-Technik soll ein und dasselbe Programm auf unterschiedlichen Computersystemen laufen können. Diese Plattformunabhängigkeit wird dadurch erreicht, dass der Quellcode zunächst in Bytecode kompiliert wird, der erst auf dem Zielsystem von der Java-Laufzeitumgebung (Java Runtime Environment, kurz JRE) beim Starten des Programms in die jeweilige Maschinensprache übersetzt wird. Der Bytecode funktioniert also als Zwischencode zwischen Programmiersprache und Maschinensprache.

Die Java-Laufzeitumgebung muss auf dem Zielsystem installiert sein. Sie existiert für weit verbreitete Betriebssysteme wie Microsoft Windows, Linux, Solaris, Mac OS X, AIX und viele andere. Daneben gibt es JREs nicht nur für Server- und Desktop-Betriebssysteme, sondern auch für viele eingebettete Systeme wie Mobiltelefone, PDAs und Smartcards sowie für andere technische Plattformen, wie Auto und TV. Die Plattformunabhängigkeit endet bei Systemen, für die keine Java Virtual Machine existiert, zumeist also ältere oder sehr exotische Systeme.

Bestandteile[Bearbeiten | Quelltext bearbeiten]

Die Java-Technik besteht aus den folgenden Teilen:

Aufbau der Java-Technik
Programmier-
sprache
Java Quelltext (.java)
JDK Entwicklungswerkzeuge
Java-Compiler, …
Java Bytecode (.class, .jar)
JRE Java Programmierschnittstelle (API)
Java Virtual Machine (JVM)
mit Just-in-time-Kompilierung
Betriebs-
system
Windows, Linux, Solaris, Mac OS X, …

Programmiersprache Java[Bearbeiten | Quelltext bearbeiten]

Java ist eine objektorientierte Programmiersprache und eingetragenes Warenzeichen der Firma Oracle. Der Entwurf der Programmiersprache Java strebte im Wesentlichen fünf Ziele an:[1][2]

Entwicklungswerkzeuge für Java-Programme[Bearbeiten | Quelltext bearbeiten]

Sie enthalten Compiler, die den Quellcode in Java-Bytecode übersetzen, Dokumentationswerkzeuge und Werkzeuge um Programme zu testen. Programme für die Java-Plattform werden in der Regel mit Hilfe der Programmiersprache Java erstellt. Die Verwendung anderer Programmiersprachen ist möglich, z. B. Nice oder Groovy.

Java-Laufzeitumgebung (Plattform)[Bearbeiten | Quelltext bearbeiten]

Die Java-Laufzeitumgebung (JRE) ist eine Softwareplattform, mit der Programme weitgehend unabhängig vom darunter liegenden Betriebssystem ausgeführt werden. Sie definiert die Anwendungsprogrammierschnittstellen (APIs) eindeutig und maschinenunabhängig und enthält die Java Virtual Machine (JVM), die für die Ausführung des Java-Bytecodes verantwortlich ist. Für die meisten Betriebssysteme ist sie kostenlos verfügbar.

Zwischen folgenden Java-Plattformen wird unterschieden:

Java Platform Java Card
Reduzierter Java-Standard, um sogenannte Java-Card-Applets auf Chipkarten ausführen zu können.
Java Platform, Micro Edition (Java ME)
Plattform für so genannte embedded consumer products wie etwa Mobiltelefone oder PDAs.
Java Platform, Standard Edition (Java SE)
Sammlung von Java-Programmierschnittstellen für den generellen Einsatz auf PCs, Servern oder ähnlichen Geräten. Die Java SE dient als Grundlage für die Java-EE- und Java-ME-Techniken.
Jakarta EE
Java SE, angereichert um Programmierschnittstellen für die transaktionsbasierte Ausführung von mehrschichtigen Unternehmens- und Web-Anwendungen.

Geschichte[Bearbeiten | Quelltext bearbeiten]

Duke, Javas Maskottchen

Die Urversion von Java – auch Oak (Object Application Kernel) genannt – wurde in einem Zeitraum von 18 Monaten vom Frühjahr 1991 bis Sommer 1992 unter dem Namen The Green Project von Patrick Naughton, Mike Sheridan, James Gosling und Bill Joy sowie neun weiteren Entwicklern im Auftrag des US-amerikanischen Computerherstellers Sun Microsystems entwickelt. James Gosling war der Hauptentwickler. Ein Überbleibsel aus dem Green-Projekt ist der Duke von Joe Palrang, der zum bekannten Symbol bzw. Maskottchen geworden ist.

Der Name Oak hatte, nach Gerüchten, seinen Ursprung in einer Eiche (englisch oak), die vor dem Fenster von James Gosling stand. Aufgrund rechtlicher Probleme musste der Name (es gab bereits eine Software dieses Namens) jedoch verworfen werden. Man entschied sich für den Namen Java nach einer starken Kaffee-Sorte, die speziell für Espresso Verwendung findet (Java-Bohne) und von den Entwicklern bevorzugt getrunken wurde.

Das Ziel war nicht nur die Entwicklung einer weiteren Programmiersprache, sondern einer vollständigen Betriebssystemumgebung, inklusive virtueller CPU, für unterschiedlichste Einsatzzwecke. Das System sollte – der Legende nach – beispielsweise eine Kaffeemaschine steuern können.

Die Entwicklung fand in einem unauffälligen Bürogebäude in der Sand Hill Road in Menlo Park statt. Während der abgeschiedenen Entwicklungsphase kam es zu keinem Austausch mit Sun Microsystems. Im Sommer 1992 schließlich war die erste Oak-basierte Anwendung fertiggestellt – „an interactive, handheld home-entertainment device controller with an animated touchscreen user interface“. Diese Technikdemonstration einer Touchscreen-basierten Gerätesteuerung mit animierter grafischer Benutzeroberfläche hatte den Namen *7 (Star Seven).

Nach der Vorführung von Star Seven, mit dem zahlreiche Geräte interaktiv gesteuert werden konnten, wurden Unternehmen aus der Kabelfernseh-Branche aufmerksam, und aus dem Hinterzimmer-Projekt The Green Project entstand das Unternehmen FirstPerson. Aus dem Büro wurde ein Bürohaus in der 100 Hamilton Avenue in Palo Alto.

Da die Belegschaft inzwischen von 13 auf 70 Mitarbeiter gewachsen und die Zeit für interaktive digitale Mehrwertdienste im Bereich des Kabelfernsehens noch nicht reif war, suchte sich das junge Unternehmen neue Betätigungsfelder. Nach einem dreitägigen Treffen von John Gage, James Gosling, Bill Joy, Patrick Naughton, Wayne Rosing und Eric Schmidt in „The Inn at Squaw Creek“ bei Lake Tahoe war schnell klar: das Internet sollte es sein.

Auf Basis des Urvaters aller grafischen Webbrowser, Mosaic, wurde ein um Java erweiterter Webbrowser geschaffen – der WebRunner (nach dem Film Blade Runner). Später wurde WebRunner in HotJava umbenannt.

Im März 1995 wurde die erste Alphaversion (1.0a2) des Java-Quellcodes für die Öffentlichkeit freigegeben. Wenig später, am 23. Mai 1995, wurde Java erstmals offiziell der Öffentlichkeit vorgestellt, in den „San Jose Mercury News“.

Der Durchbruch kam mit der Integration von Java in den Browser Netscape Navigator – besiegelt durch einen Handschlag zwischen Eric Schmidt und George Paolini von Sun Microsystems sowie Marc Andreessen von Netscape – um 4 Uhr morgens in einem Zimmer des Sheraton-Palace-Hotels in der Nähe des Tagungszentrums.

Die Firma Oracle – die im Januar 2010 Sun Microsystems kaufte – will die Java-Technik zusammen mit dem Java Community Process in Richtung freie und quelloffene Software (OpenJDK) weiterentwickeln.[3]

Der Name Java[Bearbeiten | Quelltext bearbeiten]

Der Name für die neue Technik war schnell gefunden: Die meisten Programmierer bevorzugten das Straßencafé „Java City – roasters of fine coffee“ in Menlo Park, unweit ihres Bürogebäudes, wohin sie ab und zu in der Mittagspause gingen, um nach dem Essen noch einen Kaffee zu trinken. Die beliebteste Kaffeesorte der Programmierer hieß „Java“. Dieser Name wurde deshalb auch für die neue Technik genutzt. Auch der Name „JavaBeans“ leitet sich aus dieser Begebenheit ab.

Sun Microsystems verwendet in der Vermarktung und bei der internen Entwicklung mitunter unterschiedliche Versionsnummern. So wurde die Java-Version 1.2 nicht als 1.2 vermarktet, sondern als „Java-2-Plattform“. Intern blieben die Versionsnummern bei dem 1.x-Schema, so dass sich Produktnamen wie „Java 2 Standard Edition 1.4.2“ ergaben. Diese Diskrepanz wurde zumindest bei den Produktnamen aufgegeben. Das Produkt heißt jetzt „Java Standard Edition 7“; die interne Versionsnummer ist jedoch weiterhin 1.7.

Versionen[Bearbeiten | Quelltext bearbeiten]

Legende: Ältere Version; nicht mehr unterstützt Ältere Version; noch unterstützt Aktuelle Version Aktuelle Vorabversion Zukünftige Version
Versionen und Codenamen[4]
Version Codename Veröffentlichung Ende des kostenlosen Supports
Ältere Version; nicht mehr unterstützt: JDK 1.1.4 Sparkler 12. September 1997
Ältere Version; nicht mehr unterstützt: JDK 1.1.5 Pumpkin 3. Dezember 1997
Ältere Version; nicht mehr unterstützt: JDK 1.1.6 Abigail 24. April 1998
Ältere Version; nicht mehr unterstützt: JDK 1.1.7 Brutus 28. September 1998
Ältere Version; nicht mehr unterstützt: JDK 1.1.8 Chelsea 8. April 1999
Ältere Version; nicht mehr unterstützt: J2SE 1.2 Playground 4. Dezember 1998
Ältere Version; nicht mehr unterstützt: J2SE 1.2.1 (keiner) 30. März 1999
Ältere Version; nicht mehr unterstützt: J2SE 1.2.2 Cricket 8. Juli 1999
Ältere Version; nicht mehr unterstützt: J2SE 1.3 Kestrel 8. Mai 2000 Dezember 2006[5]
Ältere Version; nicht mehr unterstützt: J2SE 1.3.1 Ladybird 17. Mai 2001
Ältere Version; nicht mehr unterstützt: J2SE 1.4.0 Merlin 13. Februar 2002 Oktober 2008[6]
Ältere Version; nicht mehr unterstützt: J2SE 1.4.1 Hopper 16. September 2002
Ältere Version; nicht mehr unterstützt: J2SE 1.4.2 Mantis 26. Juni 2003
Ältere Version; nicht mehr unterstützt: J2SE 5.0 (1.5.0) Tiger 29. September 2004 Oktober 2009[7]
Ältere Version; nicht mehr unterstützt: JSE 6.0 (Mustang)[8] 11. Dezember 2006 Februar 2013[7]
Ältere Version; nicht mehr unterstützt: JSE 7.0 (Dolphin)[8] 28. Juli 2011[9] April 2015[7]
Ältere Version; nicht mehr unterstützt: JSE 8.0 18. März 2014[10] März 2022[11]
Ältere Version; nicht mehr unterstützt: JSE 9.0 27. Juli 2017[12] März 2018[11]
Ältere Version; nicht mehr unterstützt: JSE 10.0 (18.3) 20. März 2018 September 2018[11]
Ältere Version; noch unterstützt: JSE 11.0 (18.9) LTS 25. September 2018[13] September 2023[11]
Ältere Version; nicht mehr unterstützt: JSE 12.0 19. März 2019[14] September 2019[11]
Ältere Version; nicht mehr unterstützt: JSE 13.0 17. September 2019[15] März 2020[11]
Ältere Version; nicht mehr unterstützt: JSE 14.0 17. März 2020[16] September 2020[11]
Ältere Version; nicht mehr unterstützt: JSE 15.0 15. September 2020[17] März 2021[11]
Ältere Version; nicht mehr unterstützt: JSE 16.0 16. März 2021[18] September 2021[11]
Ältere Version; noch unterstützt: JSE 17.0 LTS 14. Sep. 2021[19] Sep. 2026[11]
Ältere Version; nicht mehr unterstützt: JSE 18.0 22. März 2022[20] Sep. 2022[11]
Ältere Version; nicht mehr unterstützt: JSE 19.0 20. Sep. 2022[21] März 2023[11]
Ältere Version; nicht mehr unterstützt: JSE 20.0 21. März 2023[22] Sep. 2023[11]
Aktuelle Version: JSE 21.0 LTS 19. Sep. 2023[23] Sep. 2028[11]
Zukünftige Version: JSE 22.0 19. März 2024[23]
Zukünftige Version: JSE 23.0 17. Sep. 2024[23]
Zukünftige Version: JSE 24.0 18. März 2025[23]
Versionen und Größen[24]
Version Pakete Klassen, Enums und Interfaces Module
Ältere Version; nicht mehr unterstützt: JDK 1.0 008 0212
Ältere Version; nicht mehr unterstützt: JDK 1.1 023 0504
Ältere Version; nicht mehr unterstützt: JDK 1.2 059 1520
Ältere Version; nicht mehr unterstützt: JDK 1.3 076 1842
Ältere Version; nicht mehr unterstützt: JDK 1.4 135 2991
Ältere Version; nicht mehr unterstützt: J2SE 5.0 166 3279
Ältere Version; nicht mehr unterstützt: JSE 6.0 203 3793
Ältere Version; nicht mehr unterstützt: JSE 7.0 209 4024
Ältere Version; noch unterstützt: JSE 8.0 217 4240
Ältere Version; nicht mehr unterstützt: JSE 9.0 315[25] 6005[25] 78[25]
Ältere Version; nicht mehr unterstützt: JSE 10.0 314[26] 6002[26] 77[26]
Ältere Version; noch unterstützt: JSE 11.0 235[27] 4410[28] 59[28]/72[29]

Version 1[Bearbeiten | Quelltext bearbeiten]

Die 1996 erschienene Java-Version 1.0 enthielt noch eine überschaubare Menge von Standardpaketen, die in späteren Versionen schnell anwuchs:

  • java.lang: elementare Klassen, z. B. Object und System
  • java.io: Ein- und Ausgabe
  • java.util: z. B. Datenstrukturen und eine Datumsklasse
  • java.net: einfache Internetprotokoll-Klassen
  • java.awt: grundlegende Klassen für grafische Benutzeroberflächen
  • java.applet: eine Klasse für die bekannten Applets

Obwohl diese neue Sprache primär zum Entwickeln von Applets gedacht war, bot sie schon in der ersten Version Möglichkeiten, die weit darüber hinaus reichten.

Version 1.1[Bearbeiten | Quelltext bearbeiten]

Eine Spracherweiterung wurde 1997 mit Java 1.1 vorgenommen, die Syntax wurde um das Konzept der inneren Klassen erweitert. Das ging einher mit einem Umbau der Ereignisbehandlung hin zu einem Callback-System mit sogenannten Listenern.

Außerdem wurde die Standardbibliothek erweitert:

In den Versionen ab 1.1.5 war bereits Swing verfügbar, jedoch zählte dieses Framework noch nicht zum offiziellen Java. Besonders problematisch war, dass Swing mit Erscheinen von 1.2 eine andere Paketstruktur aufwies und eine Portierung notwendig machte.

Version 1.2[Bearbeiten | Quelltext bearbeiten]

Java 2 (JDK 1.2) erschien im Jahr 1998.[4] Mit Erscheinen dieser Version sprach Sun von Java 2, dementsprechend heißen die Pakete Java 2 Platform, Standard Edition (J2SE) und statt Java Development Kit (JDK) heißt es Java 2 Software Development Kit (J2SDK).

In dieser Version wurde neben dem bestehenden Interpreter ein Just-in-time-Compiler eingeführt; dieser beschleunigt die Ausführung von Java-Programmen deutlich. Die HotSpot Just-in-time-Kompilierung inklusive adaptiver Optimierung wurde als Erweiterung für Java 1.2 angeboten,[30] ab Java 1.3 wurde HotSpot als alleinige JVM von Sun angeboten.[31]

Erneut wurde die Standardbibliothek erweitert:

  • Neue Schnittstellen und Implementierungen für Collections, also Datenstrukturen wie Listen, Mengen und Maps (Assoziativlisten)
  • Die Oberflächenbibliothek Swing
  • Neue Grafik-Funktionen (Java 2D)
  • Drag and Drop-Funktionalität
  • Verbesserte Audio-Funktionen
  • Eine CORBA-Schnittstelle
  • Schwache Referenzen – das sind Referenzen, die den Garbage-Collector nicht daran hindern, das referenzierte Objekt zu entfernen

Im Jahr 1998 wurde auch der Java Community Process (JCP) eingeführt. Diese Organisation steuert seitdem Änderungen an der Spezifikation von Java. Für vorgeschlagene Änderungen wird ein Java Specification Request (JSR) erstellt, der verschiedene Phasen durchläuft, bevor die Änderungen in Java Einzug halten.

Version 1.3[Bearbeiten | Quelltext bearbeiten]

2000 erschien J2SE 1.3 als nächster Evolutionsschritt, die API wurde erneut erweitert. Außerdem wurde eine Engine mit Hotspot-Optimierung eingeführt. Das bedeutet, dass häufig benutzte Codefragmente (Hotspots) vom Bytecode zur Laufzeit in nativen Maschinencode übersetzt werden. Resultat war eine deutlich gesteigerte Ausführungsgeschwindigkeit.

API-Erweiterungen:

  • Java Naming and Directory Interface (JNDI)
  • Java Sound API

Version 1.4[Bearbeiten | Quelltext bearbeiten]

Erst 2002 wurde mit Erscheinen von J2SE 1.4 wieder die Sprache selbst erweitert, was zuletzt bei Version 1.1 geschehen war. Eine Unterstützung für Assertions wurde hinzugefügt. Auch die API wurde erweitert, was insbesondere die Serverprogrammierung erleichtern soll.

Die letzte Version von Java 1.4 war Java SE 1.4.2_42. „End of Public Updates“ – das Ende öffentlicher Aktualisierungen – erreichte J2SE 1.4 im Oktober 2008.[32]

Siehe auch: Servlet, Java Web Start, JSP, Jakarta EE, J2ME, Javadoc, Blackdown Java

Version 5.0[Bearbeiten | Quelltext bearbeiten]

Java 5.0 erschien am 30. September 2004 als Nachfolger der Version 1.4. Bei dem augenscheinlichen Versionssprung von 1.x auf 5 handelt es sich um die Einführung einer sog. Produktnummer. Diese Produktnummern sollen in Zukunft die Java-Versionen nach außen hin repräsentieren. Intern sollte dieselbe Produktversion nach der bekannten, traditionellen Versionsnummer bezeichnet werden. Java 5.0 entspricht also der internen Versionsnummer 1.5, Java 6.0 entsprechend 1.6 etc.[33] Die „2“ z. B. aus Jakarta EE verschwand somit ebenfalls ab Version 5.0 der Java Enterprise Edition. Sie wird nun mit Java EE 5 bezeichnet.[34]

In Version 5 gab es umfangreiche Änderungen an der Sprache sowie weitere API-Erweiterungen:

Die zunächst für Java 5 („Tiger“-Release) geplanten Erweiterungen der Ein-/Ausgabefunktionen (JSR-203)[35] wurden erst auf Java 6 („Mustang“-Release) und Anfang 2006 dann auf Java 7 („Dolphin“-Release) verschoben.

Die letzte Version von Java SE 5 war JavaSE 5.0u45. „End of Public Updates“ – das Ende öffentlicher Aktualisierungen – erreichte JavaSE 5 im Oktober 2009.[32]

Version 6[Bearbeiten | Quelltext bearbeiten]

Die Java-Version 6 wurde am 11. Dezember 2006 veröffentlicht. Besonderes Augenmerk wurde auf Diagnose, Überwachung und Management gelegt. So wurde ein Framework zur Zusammenarbeit mit diversen Skriptsprachen, wie z. B. PHP, Python, Ruby und JavaScript, eingeführt.

Weitere Neuerungen waren eine verbesserte Darstellung von Desktop-Anwendungen sowie die Integration von Java DB, einer in Java implementierten relationalen Datenbank, die auf Apache Derby basiert.

Die im Oktober 2008 veröffentlichte Version 6u10 brachte nicht, wie sonst üblich, ausschließlich Fehlerbeseitigungen, sondern diverse Änderungen der JVM, mit denen nicht bis zum Erscheinen von Java 7 gewartet wurde. Zu den wichtigsten Neuerungen, die im Vorfeld bereits gefordert wurden, gehörten unter anderem:

  • Ein „Next Generation Java Plugin“, das dem Website-Betreiber mehr Möglichkeiten über eingebundene Applets anbietet[36]
  • Der für Webapplikationen gedachte Java-Kernel, der bei Bedarf eine minimale JVM installiert und nur die nötigen Pakete herunterlädt und lokal speichert[37]
  • Der Java Quick Starter, mit dessen Hilfe die Startzeit von Java-Applikationen deutlich verringert wird.[38]

Eine vollständige Liste sowie detaillierte Beschreibungen sind der Ankündigung zum „Update 10“ zu entnehmen.[39] Weitere Verbesserungen an der virtuellen Maschine, die ursprünglich für Java 7 geplant waren, wurden in Java 6 integriert und in mehreren Schritten ab „Java 6 Update 14“ ausgeliefert.

Die letzte geplante Version von Java SE 6 war „Java SE 6 Update 45“, sie wurde trotz angekündigtem „End of Public Updates“ – dem Ende öffentlicher Aktualisierungen – für Java SE 6 für Februar 2013 im April 2013 nachgereicht. Die aktuelle Version von Java EE 6 ist „Java EE 6 Update 4“. Im Dezember 2012 begann Oracle versuchsweise, einige Installationen automatisch von JavaSE 6 auf JavaSE 7 zu aktualisieren. Für Februar 2013 war geplant, alle installierten 32-Bit-Versionen über den automatischen Mechanismus auf Java 7 zu aktualisieren.[40]

„End of Public Updates“ – das Ende öffentlicher Aktualisierungen – erreichte JavaSE 6 im Februar 2013.[32]

Version 7[Bearbeiten | Quelltext bearbeiten]

Die Java-Version 7 wurde am 28. Juli 2011 fertiggestellt.

Vor allem wurden bestehende Funktionalitäten verbessert und erweitert. Das sind unter anderem:

  • Eine neue Dateisystem-API (NIO.2), die die Geschwindigkeit von Dateisystemoperationen verbessert, bessere Möglichkeiten zum Kopieren und Verschieben von Dateien bietet, Methoden zum Traversieren von Verzeichnisstrukturen enthält und die zuverlässige Erkennung und Behandlung von symbolischen Links erlaubt.
  • Bibliotheken für die Netzwerkprotokolle Stream Control Transmission Protocol (SCTP), Sockets Direct Protocol (SDP) und TLS 1.2. Speziell unter Windows wird nach Möglichkeit nun ein neuerer IPv6-Netzwerk-Stack verwendet.
  • Aktualisierung der Unicode-Unterstützung auf Unicode 6.0 (von Unicode 4.0 in Java 6), der Datenbankschnittstelle JDBC und der Gebietsschemaparameter (Locale), die nun die Standards IETF BCP 47 und UTR 35 implementiert.
  • Das mit Java 6 Update 10 eingeführte Look-and-Feel Nimbus wird fester Bestandteil der Spezifikation.
  • Eine XRender-Pipeline für Java 2D, die die Darstellung von grafischen Elementen auf Linux beschleunigt.
  • Verbesserte Unterstützung des Java-Bytecode für dynamische Programmiersprachen.
  • Kleinere Sprachverbesserungen im Rahmen des Project Coin, wie die Nutzbarkeit von Zeichenketten in switch-Anweisungen.[41]

Eine Liste sowie detaillierte Beschreibungen der mit Java 7 umgesetzten Funktionalitäten sind der Dokumentation des OpenJDK-Projektes Java 7 zu entnehmen.[42]

Java 7 erreichte „End of Public Updates“ – das Ende öffentlicher Aktualisierungen – im April 2015.[32] Die letzte öffentlich verfügbare Version von Java 7 war „Update 80“ vom 14. April 2015, die auch „nicht-kritische“ Fehlerbehebungen enthielt.[43][44] Die „Premium-Unterstützung“ für Version 7 war bis Juli 2019 vorgesehen, die „Erweiterte Unterstützung“ bis Juli 2022.[32]

Version 8[Bearbeiten | Quelltext bearbeiten]

Java 8 erschien am 18. März 2014. Es ist die erste LTS-Version nach dem neuen Support-Schema von Oracle.[7]

Für sie gab es öffentliche und kostenlose Updates bis inkl. Januar 2019.[45] Seitdem ist für den Abruf über die Oracle-Webseite eine Registrierung erforderlich, damit kommerzielle Nutzer bis März 2022 auf kostenlose Updates und danach bis Ende 2030 auf kostenpflichtige Updates zugreifen können.[11] Parallel dazu lässt sich über Oracles separate Java-Webseite die jeweils aktuelle Version auch ohne Registrierung herunterladen (Stand 24. April 2021).[46]

Mit Java 8 wurden ursprünglich für Java 7 geplante Neuerungen nachgereicht und Synergien eingearbeitet, die sich aus dem Kauf von Java durch Oracle ergaben. Unter anderem wurden folgende Neuerungen umgesetzt:[47]

  • Integration von Oracle JRockit-Funktionalitäten wie Verbessertes Contended Locking ins OpenJDK
  • Virtuelle Erweiterungsmethoden und Closures (Projekt Lambda)
  • Durch Projekt Lambda ermöglichte Erweiterungen der Collections-API
  • Neue Date and Time API ähnlich Joda Time
  • Verbesserungen bei der Garbage Collection, Reflection, Collections, Generics und Annotations
  • Weitere kleinere Sprachverbesserungen wie beispielsweise Annotationen für Java-Typen
  • Diverse Verbesserungen hinsichtlich Sicherheit
  • Diverse Leistungsverbesserungen vor allem hinsichtlich Parallelisierung
  • Methodenimplementierung in Interfaces („Default Interface“)[48]

Version 9[Bearbeiten | Quelltext bearbeiten]

Java 9 ist am 21. September 2017 erschienen.[49] Sie ist eine „Non-LTS“-Version[7] und es gibt daher nur Updates bis zum Release der Nachfolgeversion. Java 9 brachte mit „Project Jigsaw“ ein neues Modulsystem, das Java um Module als neues Sprachfeature erweitert. Jigsaw brachte ebenfalls eine grundlegende Strukturänderungen der Java-Plattform mit sich.[50][51] Das „Project Kulla“ brachte eine Integration der jshell[52] in Java.

Version 10[Bearbeiten | Quelltext bearbeiten]

Java 10 erschien am 20. März 2018 und somit wie im Herbst 2017 angekündigt nur 6 Monate nach Version 9. Sie ist ebenfalls eine „Non-LTS“-Version.[7]

Version 11[Bearbeiten | Quelltext bearbeiten]

Java 11 wurde am 25. September 2018 als LTS-Version veröffentlicht.[13] Für den produktiven Einsatz von Oracle JRE ist seit dieser Version eine kostenpflichtige „Java SE Subscription“ erforderlich. Lediglich in Entwicklungs- und Testumgebungen bleibt es kostenfrei nutzbar. Andere Laufzeitumgebungen wie OpenJDK oder Adoptium bieten andere Unterstützungszeiträume.[53]

Version 12[Bearbeiten | Quelltext bearbeiten]

Java 12 wurde am 19. März 2019 veröffentlicht.[54]

Version 13[Bearbeiten | Quelltext bearbeiten]

Java 13 wurde am 17. September 2019 veröffentlicht.[55]

Version 14[Bearbeiten | Quelltext bearbeiten]

Java 14 wurde am 17. März 2020 veröffentlicht.[56]

Version 15[Bearbeiten | Quelltext bearbeiten]

Java 15 wurde am 15. September 2020 veröffentlicht.[57]

Version 16[Bearbeiten | Quelltext bearbeiten]

Java 16 wurde am 16. März 2021 veröffentlicht.[58]

Version 17[Bearbeiten | Quelltext bearbeiten]

Java 17 ist eine LTS-Version und wurde am 14. September 2021 veröffentlicht.[59]

Version 18[Bearbeiten | Quelltext bearbeiten]

Java 18 wurde am 22. März 2022 veröffentlicht.[60]

Version 19[Bearbeiten | Quelltext bearbeiten]

Java 19 wurde am 20. September 2022 veröffentlicht.[61]

Version 20[Bearbeiten | Quelltext bearbeiten]

Java 20 wurde am 21. März 2023 veröffentlicht.[62]

Version 21[Bearbeiten | Quelltext bearbeiten]

Java 21 ist eine LTS-Version und wurde am 19. September 2023 veröffentlicht.[63]

Lizenz[Bearbeiten | Quelltext bearbeiten]

Am 13. November 2006 gab Sun bekannt, dass bis Ende des zweiten Quartals 2007 die komplette Java-Technik unter den Lizenzbestimmungen der GPL Version 2 veröffentlicht werden soll.[64][65] Am 8. Mai 2007 teilte man mit, dass dies für den Großteil der Technik geschehen sei.[66]

Ein Problem für Entwickler freier Software bestand bis dahin darin, dass Java zwar kostenlos war, jedoch nicht die Richtlinien für freie Software erfüllte. Probleme entstanden in diesem Rahmen vor allem dann, wenn beim Erstellen von Programmen „unfreie“ Klassen von Sun verwendet wurden, die freie Java-Compiler oder Java-Laufzeitumgebungen nicht verwenden können. Anwender von freien JVMs waren in diesen Fällen gezwungen, auf die JVM von Sun zurückzugreifen. In diesem Zusammenhang wurde auch von der „Java-Falle“ (Java Trap[67]) gesprochen.

Engagierte Entwickler haben darauf reagiert und eine beachtliche Menge an freier Software zur Interpretation, Kompilierung und Ausführung von Java-Programmen entwickelt, wie z. B. GNU Classpath, GNU Compiler for Java, Kaffe, Apache Harmony oder IcedTea.

Jedoch wurden die Lizenzbedingungen für Oracles Java Compatibility Kit (JCK) von der Apache Software Foundation[68] und der Linux Standard Base Arbeitsgruppe als bewusste Verhinderung von alternativen Implementierungen wahrgenommen, was u. a. zum Ausschluss von Java aus dem aktuellen LSB-Standard 4.1 führte.[69]

Anwendungen[Bearbeiten | Quelltext bearbeiten]

Java findet seinen Einsatz zum Beispiel in folgenden Bereichen:

Kritik[Bearbeiten | Quelltext bearbeiten]

Java bietet vor allem auf Grund seiner Ausführung in einer virtuellen Maschine einige Sicherheitsvorteile gegenüber direkt ausgeführten Programmiersprachen. Ein Applet einer Webseite unterliegt beispielsweise sicherheitsbedingten Einschränkungen durch die virtuelle Maschine, dasselbe gilt analog für Java-Applikationen. All diese laufen in einer virtuellen Maschine und dürfen nicht frei auf beliebige Ressourcen zugreifen. Direkt ausgeführte Programmiersprachen (ohne virtuelle Maschine) bieten diese Sicherheitsvorkehrungen gar nicht und sind somit im Vergleich zu Java maximal unsicher.

Existieren jedoch auf Grund von Fehlern in der virtuellen Maschine oder in der Klassenbibliothek Schwachstellen in diesen Sicherheitstechniken, so kann ein bösartiges Applet oder eine bösartige Applikation diese Schwachstellen ausnutzen und unter Umständen auf Ressourcen zugreifen, auf die sie im Normalfall keine Zugriffsrechte hätte.

Java war 2012 bis 2013 mehrfach wegen derartiger Fehler in den Schlagzeilen.[70][71] Im August 2012 tauchte beispielsweise ein öffentlich verfügbarer Exploit im Internet[72] auf, der sämtliche Sandboxing- und sonstige Sicherheitsverfahren von Java umgeht, indem er sie einfach abschaltet.[73] Ein paar Tage später war dieser Exploit (CVE: 2012-4681)[74] in zahlreichen Exploit-Frameworks integriert, darunter auch in Metasploit und Blackhole. Oracle veröffentlichte daraufhin ein Notfall-Update, Experten fanden aber auch in den gepatchten Java-Versionen Sicherheitslücken.

Am 10. Januar 2013 gab das renommierte Computermagazin c’t aus Sicherheitsgründen eine Empfehlung zur Deinstallation des Java Plug-ins heraus, beim Einsatz des Internet Explorers sogar zur vollständigen Deinstallation von Java.[75] Am 11. Januar 2013 schloss sich das BSI dieser Empfehlung an.[76]

Mit den außerplanmäßigen bzw. vorgezogenen Java-Updates 7u11 bis 7u13 wurden gemäß Oracle die Sicherheitsprobleme gelöst.[77] Das BSI gab daraufhin Entwarnung für die Verwendung von Java.[78]

Weblinks[Bearbeiten | Quelltext bearbeiten]

Einzelnachweise[Bearbeiten | Quelltext bearbeiten]

  1. The Java Language Environment – 1.2 Design Goals of the JavaTM Programming Language, James Gosling und Henry McGilton, Mai 1996
  2. Java Language Overview, 1995 Sun Whitepaper
  3. Wolfgang Weigend: Die Java Plattform Strategie. (Flash) Folien zum Vortrag. Oracle, 24. August 2011, S. 5, abgerufen am 8. Januar 2012.
  4. a b Reference: J2SE Code Names. In: Java Platform, Standard Edition (Java SE). Sun Microsystems (online [abgerufen am 8. Januar 2012]).
  5. Steven Chan: Understanding J2SE 1.3 End-of-Life Implications for Apps 11i. (Online [abgerufen am 26. Juli 2018]).
  6. Java SE EOL Policy. 26. Oktober 2011, archiviert vom Original (nicht mehr online verfügbar) am 14. November 2011; abgerufen am 26. Juli 2018 (englisch).
  7. a b c d e f Oracle Java SE Support Roadmap. Abgerufen am 8. Juli 2018.
  8. a b Mustang and Dolphin… we’ll miss you (Memento vom 16. November 2006 im Internet Archive) – Verzicht auf Codenamen ab JSE 6.0, Ray Gans’s Blog, 15. August 2006; abgerufen am 12. Oktober 2009.
  9. Java 7 Releases nach Datum – Seite bei Java.com. Abgerufen am 20. November 2013.
  10. JDK 8 Schedule. Open JDK, 20. August 2012, abgerufen am 5. Oktober 2012 (englisch).
  11. a b c d e f g h i j k l m n o Oracle Java SE Support Roadmap. Oracle, 2. April 2021, abgerufen am 24. April 2021 (englisch).
  12. JDK 9. Open JDK, 5. Januar 2017, abgerufen am 5. Januar 2017 (englisch).
  13. a b Alexander Neumann: Java 11 bringt nicht nur ein geändertes Supportmodell. heise online, 25. September 2018, abgerufen am 3. Oktober 2018.
  14. JDK 12. Abgerufen am 8. Oktober 2018.
  15. JDK 13. Abgerufen am 5. November 2019.
  16. JDK 14. Abgerufen am 13. April 2020.
  17. JDK 15. Abgerufen am 8. Februar 2021.
  18. JDK 16. Abgerufen am 9. April 2021.
  19. JDK 17. Abgerufen am 23. Oktober 2021.
  20. JDK 18. Abgerufen am 12. November 2022.
  21. JDK 19. Abgerufen am 12. November 2022.
  22. JDK 20. Abgerufen am 31. März 2023.
  23. a b c d JDK Releases. Abgerufen am 17. August 2023.
  24. Robert Liguori, Patricia Liguori: Java 8 Pocket Guide – Instant Help for Java Programmers. O’Reilly Media, 2014, ISBN 978-1-4919-0086-4.
  25. a b c Java SE 9 & JDK 9. Abgerufen am 8. Oktober 2018 (englisch).
  26. a b c Java SE 10 & JDK 10. Abgerufen am 8. Oktober 2018 (englisch).
  27. cd jdk11/src; find -name package-info.java | wc --lines
  28. a b Java 11 API Reference. Abgerufen am 8. Oktober 2018 (englisch).
  29. cd jdk11/src; find -name module-info.java | wc --lines
  30. news.cnet.com
  31. sun.com
  32. a b c d e Oracle Java SE Support Roadmap. oracle.com, 22. April 2015, abgerufen am 27. April 2015 (englisch).
  33. Version 1.5.0 or 5.0?, Java 5 Release Notes, abgerufen am 5. Februar 2009
  34. Java API Specifications. Oracle, abgerufen am 17. Mai 2019.
  35. JSR 203: More New I/O APIs for the Java Platform („NIO.2“). In: Java Community Process. 2011, abgerufen am 5. Oktober 2014.
  36. Oracle.com: Next-Generation Java Plug-In Technology Introduced in Java SE 6 update 10
  37. Java Runtime Environment Installation for JavaSE 6u10
  38. JavaTM Quick Starter for JavaSE 6u10
  39. Java SE 6 Update 10 FAQ: JavaTM SE 6 Update Release Notes.
  40. oracle: Java 6 Auto-Update to Java 7. oracle.com, abgerufen am 4. Januar 2013.
  41. Java Programming Language Enhancements – Liste der Core Java Neuheiten in Versionen 5, 6, 7
  42. JDK 7 Features
  43. Java SE Runtime Environment 7 Downloads. oracle.com, April 2015, abgerufen am 27. April 2015 (englisch).
  44. Java-Freigaben. (Versionen 7 und 8). java.com, 18. Juli 2017, abgerufen am 18. Oktober 2017.
  45. Gabriela Motroc: No more public updates for Java 8 business users after January 2019 [Poll] – JAXenter. JAXenter, 23. April 2018, abgerufen am 24. April 2021 (englisch).
  46. Java. Oracle, abgerufen am 24. April 2021 (englisch).
  47. What’s New in JDK 8. Oracle, abgerufen am 24. April 2021 (englisch).
  48. How does Java 8' new default interface model works bei stackoverflow.com
  49. JDK 9. In: OpenJDK. Oracle Corporation and/or its affiliates, 7. Juni 2017, abgerufen am 15. Juni 2017 (englisch, Projektplanung für JDK 9).
  50. Nächster Schritt der Java-Modularisierung: Project Jigsaw wandert in JDK-9-Branch. Heise-Verlag, 12. März 2016, abgerufen am 22. Februar 2017.
  51. Kristine Schaal, Rüdiger Grammes, Martin Lehmann: Java 9 bringt das neue Modulsystem Jigsaw. Informatik Aktuell, 15. Februar 2018, abgerufen am 3. Mai 2019.
  52. jshell JEP. Open JDK, 5. November 2015, abgerufen am 10. November 2015 (englisch).
  53. Hendrik Ebbers, Timo Brandstätter: Wird Java jetzt kostenpflichtig? heise online, 28. August 2018, abgerufen am 3. Oktober 2018.
  54. JDK 12. In: OpenJDK. Abgerufen am 22. März 2019.
  55. JDK 13. In: OpenJDK. Abgerufen am 17. September 2019.
  56. JDK 14. In: OpenJDK. Abgerufen am 25. März 2020.
  57. JDK 15. Abgerufen am 6. Oktober 2020.
  58. JDK 16. Abgerufen am 9. April 2021.
  59. openjdk.java.net
  60. openjdk.java.net
  61. openjdk.java.net. Abgerufen am 2. November 2022.
  62. openjdk.java.net. Abgerufen am 19. September 2023 (englisch).
  63. openjdk.java.net. Abgerufen am 19. September 2023 (englisch).
  64. sun.com (Memento vom 26. August 2007 im Internet Archive)
  65. Mike Loukides: At last! Open Source Java. November 2006, archiviert vom Original (nicht mehr online verfügbar) am 6. Oktober 2014; abgerufen am 6. Oktober 2014.
  66. JAVAONE: Sun – The bulk of Java is open sourced (Memento vom 14. April 2008 im Internet Archive)
  67. Richard Stallman: Frei, aber gefesselt – die Java-Falle. 12. April 2004
  68. The ASF Resigns From the JCP Executive Committee. In: The Apache Software Foundation Blog. Apache Software Foundation, 9. Dezember 2010, abgerufen am 5. Oktober 2014.
  69. Linux Standard Base 4.1 ohne Java. heise.de, 11. März 2011, abgerufen am 16. November 2011: „Java, im Status „Trial Use“ in die Linux Standard Base 4.0 aufgenommen, wurde aus der neuen Version wieder entfernt. Grund dafür sind Lizenzierungsprobleme mit dem Java Compatibility Kit (JCK), dessen Bestehen Voraussetzung dafür ist, dass sich eine Java-Implementierung Java-kompatibel nennen darf. Die Apache Software Foundation wirft Oracle wie schon zuvor Sun vor, mit den Lizenzbedingungen des JCK konkurrierende Java-Implementierungen auszuschließen.
  70. Java-0-Day unter der Lupe. Heise Security, abgerufen am 22. Februar 2013.
  71. Großes Notfall-Update für Java. Heise Security, abgerufen am 22. Februar 2013.
  72. Java-Exploit (CVE-2012-4681). Archiviert vom Original am 17. Februar 2013; abgerufen am 23. März 2013.
  73. Java-0-Day unter der Lupe. Heise Security, abgerufen am 22. Februar 2013.
  74. CVE-2012-4681 bei MITRE (englisch)
  75. Gefährliche Lücke in aktueller Java-Version. In: Heise Security. Abgerufen am 10. Januar 2013.
  76. Kritische Schwachstelle in aktueller Java-Laufzeitumgebung. Bundesamt für Sicherheit in der Informationstechnik (BSI), archiviert vom Original am 18. Januar 2013;.
  77. February 2013 Critical Patch Update for Java SE Released. Abgerufen am 5. Februar 2013.
  78. Schwachstelle in aktueller Java-Laufzeitumgebung geschlossen. Update des Herstellers liegt vor, BSI empfiehlt Internetnutzern Einspielung des Updates. Bundesamt für Sicherheit in der Informationstechnik (BSI), 14. Januar 2013, abgerufen am 26. März 2013: „Nach Installation des Java-Sicherheitsupdates können auch die Browser Plugins wieder aktiviert und genutzt werden.“