5.9 Strings zusammenhängen (konkatenieren)
Um aus Teilstrings einen neuen String zu generieren, bietet Java diverse Möglichkeiten:
den Plus-Operator bei involvierten String-Objekten
die concat(String)-Methode der Klasse String
die Klassen StringBuilder und StringBuffer mit ihren append(…)-Methoden
eine Methode join(…) bei der Klasse String bzw. die Hilfsklasse java.util.StringJoiner zum Zusammenhängen von Teilen mit einem gemeinsamen Trennzeichen
format(…) von String bzw. die Hilfsklasse java.util.Formatter
Dazu gesellen sich ein paar Methoden und Typen, die der Konkatenation zuzuordnen sind:
zwei besondere appendXXX(…)-Methoden zum Anhängen von Zeichenfolgen im Zuge einer Ersetzung im Zusammenhang mit regulären Ausdrücken
ein besonderer StringWriter mit append(…)- und write(…)-Methoden
[»] Hinweis
Intern setzt der Java-Compiler von Oracle bis Version 9 die Aneinanderreihung mit + über Methoden der Klassen String und StringBuilder[ 142 ](In älteren Java-Versionen, in denen es noch kein StringBuilder gab, kam StringBuffer zum Einsatz. ) um. Aus
String s = "a" + b + c;
generiert der Java-Compiler (vor Java 9):
String s = new StringBuilder().append( "a" ).append( b ).append( c ).toString();
Das bedeutet: Die Konkatenation über + ist insbesondere in Schleifen nicht performant. Hier sollten Entwickler vor der Schleife ein StringBuilder aufbauen und im Schleifenrumpf die append(…)-Methoden aufrufen.
Tipp: Der neu aufgebaute StringBuilder sollte im Idealfall im Konstruktor gleich die passende Puffergröße bekommen. Ab Java 9 versucht die JVM, direkt die Konkatenation zu optimieren.
5.9.1 Strings mit StringJoiner zusammenhängen
Um Strings zu einem großen Ergebnis zusammenzuhängen und dabei einen gemeinsamen Trenner zu verwenden, bietet String die praktische Hilfsmethode join(…). Dahinter steht eine kleine Klasse StringJoiner, die auch direkt genutzt werden kann.
[zB] Beispiel
StringJoiner sj = new StringJoiner( ", " );
sj.add( "1" ).add( "2" ).add( "3" );
System.out.println( sj.toString() ); // 1, 2, 3
Der Delimiter – der natürlich auch ein Leerstring "" sein kann – wird zwischen jedes Element gesetzt, das hinzugefügt wurde. Die im Beispiel eingesetzte Methode add(CharSequence) nimmt einen Join-String vom Typ CharSequence an und liefert den aktuellen StringJoiner zurück, sodass sich die add(…)-Aufrufe kaskadieren lassen. Mit der Methode merge(StringJoiner) lässt sich der Inhalt eines anderen StringJoiner integrieren.
Zusammenhängen mit Infix, Präfix und Suffix
Nicht nur das Trennzeichen selbst lässt sich angeben, sondern auch ein Startzeichen und Endzeichen.
[zB] Beispiel
Die Ausgabe soll mit einem »{« beginnen und mit einem »}« enden:
StringJoiner sj = new StringJoiner( ", ", "{", "}" );
Nichts zum Zusammenhängen gegeben
Es kommt vor, dass dem StringJoiner nichts zum Zusammenfügen gegeben wird. Dann wird er dennoch Präfix und Suffix einsetzen:
StringJoiner sj = new StringJoiner( ", ", "{", "}" );
System.out.println( sj.toString() ); // {}
Ist das unerwünscht, gibt setEmptyValue(CharSequence) ein Substitut an, das genau dann zum Zuge kommt, wenn kein add(…) etwas dem StringJoiner hinzugefügt hat:
StringJoiner sj = new StringJoiner( ", ", "{", "}" ).setEmptyValue("<nix>");
System.out.println( sj.toString() ); // <nix>
Zusammengefasst bietet die Klasse zwei Konstruktoren und fünf Methoden:
class java.util.StringJoiner
StringJoiner(CharSequence delimiter)
StringJoiner(CharSequence delimiter, CharSequence prefix, CharSequence suffix)
StringJoiner add(CharSequence newElement)
StringJoiner merge(StringJoiner other)
StringJoiner setEmptyValue(CharSequence emptyValue)
int length()
String toString()
[»] Hinweis
Eigentlich ist die Klasse StringJoiner ziemlich schwach, und selbst String.join(…) ermöglicht es, Zeichenketten als Sammlung vom Typ Iterable anzunehmen, was StringJoiner, die Implementierung von String.join(…), selbst nicht erlaubt.