int[] ints1 = { 0 };
int[] ints2 = { 1,2 };
int[] ints3 = { };
int[] ints4 = { 3 };
int[] ints = Stream.of(ints1, ints2, ints3, ints4).flatMapToInt(IntStream::of).toArray();
System.out.println(Arrays.toString( ints ));
Autor: Christian Ullenboom
this für kaskadierte Methoden und Builder
Die append(…)-Methoden bei StringBuilder liefern die this-Referenz, sodass sich Folgendes schreiben lässt:
StringBuilder sb = new StringBuilder(); sb.append( "Android oder iPhone" ).append( '?' );
Jedes append(…) liefert das StringBuilder-Objekt, auf dem es aufgerufen wird – wir können also Methoden kaskadiert anhängen oder es bleiben lassen.
Wir wollen diese Möglichkeit bei einem Zauberer (Klasse Wizard) programmieren, sodass die Methoden name(String) und age(int) Spielername und Alter zuweisen. Beide Methoden liefern ihr eigenes Wizard-Objekt über die this-Referenz zurück:
class Wizard {
String name = "";
int age;
Wizard name( String name ) { this.name = name; return this; }
String name() { return name; }
Wizard age( int item ) { this.age = item; return this; }
int age() { return age; }
String format() {
return name + " ist " + age;
}
}
Erzeugen wir einen Wizard, und kaskadieren wir einige Methoden:
Wizard gundalf = new Wizard().name( "Gundalf" ).age( 60 ); System.out.println( gundalf.name() ); // Gundalf System.out.println( gundalf.format() ); // Gundalf ist 60
Der Ausdruck new Wizard() liefert eine Referenz, die wir sofort für den Methodenaufruf nutzen. Da name(String) wiederum eine Objektreferenz vom Typ Wizard liefert, ist dahinter direkt .age(int) möglich. Die Verschachtelung von name(„Gunalf“).age(60) bewirkt, dass Name und Alter gesetzt werden und der jeweils nächste Methodenaufruf in der Kette über this eine Referenz auf dasselbe Objekt, aber mit verändertem internem Zustand bekommt.
Beispiele dieser Bauart sind in der Java-Bibliothek an einigen Stellen zu finden. Sie werden auch Builder genannt.
Hinweis: Die Methode Wizard name(String) ist mit ihrer Rückgabe praktisch, verstößt aber aus zwei Gründen gegen die JavaBeans-Konvention: Setter dürfen keine Rückgabe haben und müssen immer mit set beginnen. JavaBeans sind also nicht so dieser kompakten Builder-Schreibweise „kompatibel“.
Besser dokumentierte NullPointerException in Java 14
Microsoft arbeitet am OpenJDK mit
https://mail.openjdk.java.net/pipermail/discuss/2019-October/005173.html:
Subject: Microsoft’s Ready do Contribute to OpenJDK Hi OpenJDK Community, In the past week Microsoft formally signed the Oracle Contributor Agreement, in which Oracle Inc. promptly acknowledged and welcomed us to the project. On behalf of the Microsoft Java Engineering Team, I’d like to say that we are thrilled to officially join the OpenJDK project and be ready to work with you. As many of you may know, Microsoft and its subsidiaries are heavily dependent on Java in many aspects, and also offers Java runtimes in its Microsoft Azure cloud to its customers. Microsoft recognizes the immense value that Oracle’s successful and effective stewardship of the OpenJDK project has bought Java and the wider software ecosystem and we look forward to playing our part in contributing back! The team will initially be working on smaller bug fixes and backports so that we can learn how to be good citizens within OpenJDK. For example, we already understand that discussing changes first before posting patches is preferred and I'm sure there's more for us to learn as well. The Java engineering team led by Martijn Verburg [1] is already engaged with other Microsoft groups and its subsidiaries who are using Java, as well as its partners in the Java ecosystem such as Azul Systems, Oracle, Pivotal, Red Hat, Intel, SAP and others, and the overall team will be joining the many OpenJDK mailing lists to start conversations and participating. We look forward to participating in the future of Java. [1] martijn.verburg at microsoft.com<mailto:martijn.verburg at microsoft.com> Best regards Bruno Borges Product Management for Java, Microsoft Developer Division
Mehr zu der Geschichte unter
- https://jaxenter.com/microsoft-ready-contribute-openjdk-163550.html
Spring Framework 5.2 fertig
Ankündigung im Blog https://spring.io/blog/2019/09/30/spring-framework-5-2-goes-ga:
Spring Framework 5.2 requires JDK 8 or higher and specifically supports JDK 11 as the current long-term support branch as well as JDK 13 as the latest OpenJDK release. It comes with many performance improvements (affecting startup time as well as peak performance) and further steps taken towards GraalVM native image support.
This release deeply integrates with Kotlin 1.3 and provides first-class support for Kotlin coroutines on top of Spring WebFlux. Furthermore, it comes with reactive messaging integration for the RSocket protocol as well as reactive transaction management for R2DBC, MongoDB and Neo4j (with datastore integration provided by Spring Data’s modules).
As of the upcoming Spring Boot 2.2 RC1 release, you’ll be able to consume Spring Framework 5.2 GA through start.spring.io!
Wichtige Links:
Finale Variablen und der Modifizierer final
Variablen können mit dem Modifizierer final deklariert werden, sodass genau eine Zuweisung möglich ist. Dieses zusätzliche Schlüsselwort verbietet folglich eine weitere Zuweisung an diese Variable, sodass sie nicht mehr verändert werden kann. Ein üblicher Anwendungsfall sind Konstanten.
int width = 40, height = 12; final int area = width * height; final int perimeter; final var random = Math.random() * 100; perimeter = width * 2 + height * 2; area = 200; // Compilerfehler
perimeter = 100; // Compilerfehler
Im Fall einer versuchten zweiten Zuweisung meldet der Compiler von Eclipse: »The final local variable … cannot be assigned. It must be blank and not using a compound assignment.«; IntelliJ meldet über den Java-Compiler »cannot assign a value to final variable …«.
Java erlaubt bei finalen Werten eine aufgeschobene Initialisierung. Das heißt, dass nicht zwingend zum Zeitpunkt der Variablendeklaration ein Wert zugewiesen werden muss. Das sehen wir im Beispiel an der Variablen perimeter.
Werden Variablen deklariert und initialisiert können final und var zusammen eingesetzt werden; einige Programmiersprachen bieten hier ein eigenes Schlüsselwort, wie val, Java jedoch nicht.
Ausblick
Auch Objektvariablen und Klassenvariablen können final sein. Allerdings müssen die Variablen dann entweder bei der Deklaration belegt werden, oder in einer aufgeschobenen Initialisierung im Konstruktor. Das Schlüsselwort final hat noch zusätzliche Bedeutungen im Zusammenhang mit Vererbung.
Eclipse 2019-09 freigegeben
Java 13 ist fertig
… und besonders spannend ist das nicht mehr. Na ja, einige Zusammenfassungen:
Jakarta EE 8 ist fertig
Zum Weiterlesen: https://jakarta.ee/release/
Neue Paketnamen gibt es noch nicht: https://jakarta.ee/specifications/platform/8/apidocs/ zeigt noch javax an.
WildFly ist schon Jakarta EE 8 Certified: https://wildfly.org/news/2019/09/12/WildFly_Jakarta_EE_8/
Gradle 5.6 freigegeben
Details unter https://docs.gradle.org/5.6/release-notes.html
JDK 13 ist in Release Candidate Phase
Laut https://mail.openjdk.java.net/pipermail/jdk-dev/2019-August/003250.html:
Per the JDK 13 schedule [1], we are now in the Release Candidate phase. The stabilization repository, jdk/jdk13, is open for P1 bug fixes per the JDK Release Process (JEP 3) [2]. All changes require approval via the Fix-Request Process [3]. If you’re responsible for any of the bugs on the RC candidate-bug list [4] then please see JEP 3 for guidance on how to handle them. We’ll tag the first Release Candidate build shortly. - Mark [1] https://openjdk.java.net/projects/jdk/13/#Schedule [2] https://openjdk.java.net/jeps/3 [3] https://openjdk.java.net/jeps/3#Fix-Request-Process [4] https://j.mp/jdk-rc
Weiteres unter http://www.tutego.de/java/jdk-13-java-13-openjdk13.html.
IntelliJ IDEA 2019.2 (Jul 24)
Details zu dem Update unter https://www.jetbrains.com/idea/whatsnew/#v2019-2.
JDK 12.0.2
Im Wesentlichen nur Root-Zertifkate entfernt: https://jdk.java.net/12/release-notes
Java-Programme nativ compiliert vielleicht bald auf iOS
So stellt es der Artikel https://www.infoworld.com/article/3407781/a-plan-to-bring-java-to-ios.html vor.
Kerngedanke: Das Projekt OpenJDK Mobile wieder aktivieren, GraalVM ahead-of-time Compiler nutzen.
WildFly 17.0.1 Final released
Zur Ankündigung siehe https://wildfly.org/news/2019/07/07/WildFly-1701-Released/
Red Hat spricht von harten Bugs, die in diesem Update behoben wurden, zu den Details: https://issues.jboss.org/secure/ReleaseNote.jspa?projectId=12313721&version=12342471
Google Guava 28.0 erschienen
Änderungen laut https://github.com/google/guava/releases/tag/v28.0:
collect: AddedDuration-based overloads to someQueuesmethods. (21d06cf)net: AddedMediaTypefor „application/geo+json“. (36cd5cf)net: Added a number of constants toHttpHeaders.concurrent: Removed deprecatedCheckedFutureand related utilities. (3dd22fe)concurrent: AddedDuration-based overloads to many methods.concurrent: Removed@BetafromsetFuture. (5ec1360)concurrent: Added deprecatedFluentFuture.from(FluentFuture)to point out redundant code. (f9f2807)graph: AddedGraphBuilder.immutable(),ValueGraphBuilder.immutable()andNetworkBuilder.immutable()for building immutable graphs in a fluent way.- J2ObjC: Fixed crashes from use of
ImmutableMap.entrySet(). (74fc49f)
In Projekte von start.spring.io vor dem Download reinschauen
Details siehe https://spring.io/blog/2019/07/04/explore-the-project-on-start-spring-io

CDI geht von Red Hat zur Eclipse-Foundation
Details siehe https://projects.eclipse.org/proposals/jakarta-contexts-and-dependency-injection
Das ist vernünftig, da auch der Rest von Jakarta EE bei der Eclipse Foundation liegt.
JEP354: Switch Expressions in Java 13
Die Switch Expressions kommen in Java 13 mit einer etwas anderen Syntax: https://mail.openjdk.java.net/pipermail/jdk-dev/2019-May/003038.html.
https://openjdk.java.net/jeps/354
So gibt es bei Rückgaben nun yield.
Der Restwert-Operator %
Eine Ganzzahldivision muss nicht unbedingt glatt aufgehen, wie im Fall von 9/2. In diesem Fall gibt es den Rest 1. Diesen Rest liefert der Restwert-Operator (engl. remainder operator), oft auch Modulo genannt.[1] Die Operanden können auch negativ sein.
Beispiel: System.out.println( 9 % 2 ); // 1
Die Division und der Restwert richten sich in Java nach einer einfachen Formel: (int)(a/b) × b + (a%b) = a.
Beispiel: Die Gleichung ist erfüllt, wenn wir etwa a = 10 und b = 3 wählen. Es gilt: (int)(10/3) = 3 und 10 % 3 ergibt 1. Dann ergeben 3 * 3 + 1 = 10.
Aus dieser Gleichung folgt, dass beim Restwert das Ergebnis nur dann negativ ist, wenn der Dividend negativ ist; das Ergebnis ist nur dann positiv, wenn der Dividend positiv ist. Es ist leicht einzusehen, dass das Ergebnis der Restwert-Operation immer echt kleiner ist als der Wert des Divisors. Wir haben den gleichen Fall wie bei der Ganzzahldivision, dass ein Divisor mit dem Wert 0 eine ArithmeticException auslöst und bei Fließkommazahlen zum Ergebnis NaN führt.
System.out.println( „+5% +3 = “ + (+5% +3) ); // 2
System.out.println( „+5 / +3 = “ + (+5 / +3) ); // 1
System.out.println( „+5% -3 = “ + (+5% -3) ); // 2
System.out.println( „+5 / -3 = “ + (+5 / -3) ); // -1
System.out.println( „-5% +3 = “ + (-5% +3) ); // -2
System.out.println( „-5 / +3 = “ + (-5 / +3) ); // -1
System.out.println( „-5% -3 = “ + (-5% -3) ); // -2
System.out.println( „-5 / -3 = “ + (-5 / -3) ); // 1
Gewöhnungsbedürftig ist die Tatsache, dass der erste Operand (Dividend) das Vorzeichen des Restes definiert und niemals der zweite (Divisor).
Hinweis: Um mit value % 2 == 1 zu testen, ob value eine ungerade Zahl ist, muss value positiv sein, denn -3 % 2 wertet Java zu –1 aus. Der Test auf ungerade Zahlen wird erst wieder korrekt mit value % 2 != 0.
Restwert für Fließkommazahlen
Der Restwert-Operator ist auch auf Fließkommazahlen anwendbar, und die Operanden können wiederum negativ sein.
Beispiel: Teste, ob eine double-Zahl doch eine Ganzzahl ist: (d % 1) == 0. Wem das zu verrückst ist, der nutzt alternativ d == Math.rint(d).
Restwert für Fließkommazahlen und Math.IEEEremainder( ) *
Über die oben genannte Formel können wir auch bei Fließkommazahlen das Ergebnis einer Restwert-Operation leicht berechnen. Dabei muss beachtet werden, dass sich der Operator nicht so wie unter IEEE 754 verhält. Denn diese Norm schreibt vor, dass die Restwert-Operation den Rest von einer rundenden Division berechnet und nicht von einer abschneidenden. So wäre das Verhalten nicht analog zum Restwert bei Ganzzahlen. Java definiert den Restwert jedoch bei Fließkommazahlen genauso wie den Restwert bei Ganzzahlen. Wünschen wir ein Restwert-Verhalten, wie IEEE 754 es vorschreibt, so können wir die statische Bibliotheksmethode Math.IEEEremainder(…)[2] verwenden.
Auch bei der Restwert-Operation bei Fließkommazahlen werden wir niemals eine Exception erwarten. Eventuelle Fehler werden, wie im IEEE-Standard beschrieben, mit NaN angegeben. Ein Überlauf oder Unterlauf kann zwar vorkommen, aber nicht geprüft werden.
[1] Mathematiker unterscheiden die beiden Begriffe Rest und Modulo, da ein Modulo nicht negativ ist, der Rest in Java aber schon. Das soll uns aber egal sein.
[2] Es gibt auch Methoden, die nicht mit Kleinbuchstaben beginnen, wobei das sehr selten ist und nur in Sonderfällen auftritt. ieeeRemainder() sah für die Autoren nicht nett aus.