String erzeugen sehr langsam

Thallius

Top Contributor
Hallo,

ich erzeuge einen sehr langen String, welcher danach in en CSV File gepseichert wird.
Leider dauert das Erzeugen des Strings bei rund 12000 Zeilen und 8 Spalten fast 5min. Das kann es ja nicht sein. Der Code ist denkbar einfach

Java:
    String text = "";

    int rows = model.getRowCount();
    int columns = model.getColumnCount();

    for(int i = 0; i < rows; i++)
    {
           for(int j = 0; j < columns; j++)
           {
                  String value = (String) model.getValueAt(i, j);
                  if(value != null)
                       text+="=\""+value+"\"";
                    if(j < rows - 1)
                        text+=";";
            }
            text+="\r\n";
     }

Wenn ich die Zeilen mit text+= entferne läuft die Schleife in einem Bruchteil einer Sekunde durch. Sobald ich die erhaltene Werte an den String anhänge wird es unerträglich langsam.

Warum ist das? Was kann man ändern?

Gruß

Claus
 
Zuletzt bearbeitet von einem Moderator:

stg

Top Contributor
Hast du's mal mit einem StringBuilder probiert? Eventuell die anfängliche Größe zu Beginn hoch ansetzen, um viel Bit-Schubserei beim implziten vergrößern zu vermeiden?
Oder einfach alle X Zeilen bereits in die Datei schreiben und parallel dazu direkt die nächsten X Zeilen "berechnen"'.
Das Problem lässt sich übrigens auch prima parallelisieren, falls das eine Option ist. Da musst du dann natürlich nur beim Schreiben aufpassen.
Ich hab keine Erfahrungswerte, was tatsächlich am schnellsten ist, aber das wären Möglichkeiten, die du mal mit wenig Aufwand durchprobieren könntest. Insbesondere die erste einfache Variante kann schon sehr viel bringen. Da wird zwar intern schon viel implizit optimiert und für die Konkatenierung von Strings ohnehin der gleiche Bytecode generiert, wie bei der direkten Verwendung eines StringBuilders, aber ich kann mir vorstellen, dass "Java" da nicht alle Optimierungsmöglichkeiten sieht bei der gegebenen Verschachterlung
 
Zuletzt bearbeitet:

InfectedBytes

Top Contributor
+= Erzeugt jedesmal einen neuen String wärend der Stringbuilder den alten bearbeitet ;)
nicht ganz, der StringBuilder bearbeitet keinen alten String, sonder er speichert die chars in einem Array. Falls das Array zu klein wird, wird eben ein größeres erstellt und die Daten rüberkopiert. Wenn man mit dem einfügen fertig ist, wird ein einzelner String erzeugt.
 

stg

Top Contributor
Nach jedem + definitiv nicht (siehe mein Einwand oben). Nach jedem += möglicherweise ja, da bin ich nicht sicher, wie schlau der Compiler da tatsächlich ist.
 

InfectedBytes

Top Contributor
im Grunde nutzt der Compiler auch einen StringBuilder, aber eben für jedes statement ein neuen:
Java:
x = stringA + stringB + stringC;
wird im Grunde zu
Java:
StringBuilder sb = new StringBuilder();
sb.append(stringA);
sb.append(stringB);
sb.append(stringC);
x = sb.toString();
 

Viktim

Bekanntes Mitglied
Ich meiner er sagt bei:

Java:
String a = b + c + d;
das:
Java:
String a = sb.append(a).append(b).toString();
a = sb.append(a).append(c).toString();
a = sb.append(a).append(d).toString();
 

InfectedBytes

Top Contributor
Ich meiner er sagt bei:

Java:
String a = b + c + d;
das:
Java:
String a = sb.append(a).append(b).toString();
a = sb.append(a).append(c).toString();
a = sb.append(a).append(d).toString();
Definitiv nicht, zumal du a benutzt obwohl du es gerade erst definierst.
Schau dir notfalls einfach den bytecode an, dann siehst du das folgendes passiert:
Java:
public static String test(String a, String b, String c) {
    return a+b+c;
}
// wird zu:
public static java.lang.String test(java.lang.String, java.lang.String, java.lang.String);
    Code:
       0: new           #2                  // class java/lang/StringBuilder
       3: dup
       4: invokespecial #3                  // Method java/lang/StringBuilder."<init>":()V
       7: aload_0
       8: invokevirtual #4                  // Method java/lang/StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
      11: aload_1
      12: invokevirtual #4                  // Method java/lang/StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
      15: aload_2
      16: invokevirtual #4                  // Method java/lang/StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
      19: invokevirtual #5                  // Method java/lang/StringBuilder.toString:()Ljava/lang/String;
      22: areturn
}
//also quasi einfach alles appenden und einmal toString

wäre ja auch sonst ziemlich dumm vom Compiler unnötigerweise so viele zwischen Strings zu erzeugen^^
 
Zuletzt bearbeitet:

stg

Top Contributor
Insgesamt dann also etwa so:

Code:
final String LNBREAK = "\r\n";

final int rows = model.getRowCount();
final int columns = model.getColumnCount();

StringBuilder sb = new StringBuilder();
for(int i = 0; i < rows; i++) {
    for(int j = 0; j < columns; j++) {
        String value = (String) model.getValueAt(i, j);
        if(value != null)
            sb.append('=').append('"').append(value).append('"');
        if(j < rows - 1)
            sb.append(';');
    }
    sb.append(LNBREAK);
}
String text = sb.toString();

Fällt einem noch was ein? :p

@Thallius Wie viel hat's denn nun tatsächlic gebracht?
 

InfectedBytes

Top Contributor
wenn möglich schonmal die Kapazität so gut es geht angeben, damit möglichst selten ein größeres Array erzeugt werden muss.
Java:
StringBuilder sb = new StringBuilder(10000);
 

nvidia

Bekanntes Mitglied
[....]
Code:
final String LNBREAK = "\r\n";
[...]
System.lineSeparator()

Davon abgesehen, es findet hier niemand unzweckmäßig jede Zeile einer Tabelle, mit der nichts besonderes gemacht wird, in einem langen String zu verketten um diesen dann in eine Datei zu schreiben? Würde man eine zusammengebastelte Zeile gleich an eine Einheit abgeben die sie in eine Datei schreibt benötigt man im besten Fall nur Speicher für ebendiese Zeile in String-Darstellung. Das Wegschreiben kann auch gerne asynchron laufen.
 

Thallius

Top Contributor
Hi Leute,

sorry für die späte Antwort aber Meeting reiht sich gerade an Meeting:)

Also ich habe gar nicht erst groß mit dem Stringbuilder probiert sondern gleich, die natürlich viel schlauere Lösung, den Code so geändert, dass jede Zeile direkt ins File geschrieben wird. Das hatte ich ursprünglich auch eigentlich so gemacht, hatte es dann aber irgendwann aus mir nciht mehr unerfindlichen Gründen wieder geändert.

Nun läuft alles innerhalt 1 Sekunde ab.

Gruß

Claus
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
P Objekt einer Klasse erzeugen, die als String vorliegt Allgemeine Java-Themen 3
multiholle Objekt einer Klasse anhand eines String erzeugen Allgemeine Java-Themen 3
V Aus String -> Objekt einer Klasse erzeugen Allgemeine Java-Themen 7
G Probleme bei String Übergabe um Public Key zu erzeugen ? Allgemeine Java-Themen 6
D String von 512Bytes erzeugen Allgemeine Java-Themen 4
C EML Email Text in String wandeln Allgemeine Java-Themen 9
OnDemand Java String in Hashmap als Key NULL Allgemeine Java-Themen 27
JAnruVA Datentypen Berechneten String-Wert in Double umwandeln um weiter zu rechnen Allgemeine Java-Themen 7
M String Allgemeine Java-Themen 10
M Suche nach String mit unbekannten characters Allgemeine Java-Themen 53
kodela String kann nicht zu Pfad konvertiert werden Allgemeine Java-Themen 16
melaniemueller Einzelne Zeile aus einer txt Datei in einem String speichern Allgemeine Java-Themen 12
E Objekte in einen String packen und wieder laden Allgemeine Java-Themen 5
M Map<String,String>funktioniert nicht richtig Allgemeine Java-Themen 4
O String in Long Hexerdezimal umwandel Allgemeine Java-Themen 14
N String vergleichen. Allgemeine Java-Themen 27
P String.replace() funktioniert nicht? Allgemeine Java-Themen 3
SaschaMeyer Arbeitet String.split falsch? Allgemeine Java-Themen 4
M Switches ohne String Allgemeine Java-Themen 18
AmsananKING String Iteration Allgemeine Java-Themen 5
S Shuffle String aus if-clause Allgemeine Java-Themen 11
Besset Variablen Ist String = "" + int inordnung? Allgemeine Java-Themen 6
M Map <Long, String> zu Map<String, Long> Allgemeine Java-Themen 9
S String Encoding Verständnisproblem Allgemeine Java-Themen 22
N Prüfen, ob ein String 2x das selbe Zeichen hat Allgemeine Java-Themen 10
SaftigMelo Bug Fixen von String-spliten Allgemeine Java-Themen 8
Monokuma String List nach Zahlen und Worten sortieren Allgemeine Java-Themen 9
Kingamadeus2000 Alle mehrfach vorkommenden Buchstaben rekursiv aus einem String entfernen. Allgemeine Java-Themen 6
YohnsonM String - Aufteilung und Nutzung einzelner Chars Allgemeine Java-Themen 7
O Formatierte String ausgabe bei vier Variablen in einer Zeile Allgemeine Java-Themen 1
S String umbenennen: wie? Allgemeine Java-Themen 4
x46 String Format Fehler Allgemeine Java-Themen 2
S ISO 8601 -> getter / setter String Allgemeine Java-Themen 3
L String zu repräsentativen Wert Allgemeine Java-Themen 0
H Array mit dem Datentype String[] initializieren Allgemeine Java-Themen 7
L ArrayList mit String Arrays in ein Array umwandeln Allgemeine Java-Themen 1
L regex ganzer string? Allgemeine Java-Themen 2
L Ist ein string ein erlaubter variabel name? Allgemeine Java-Themen 2
Z JNA Cpp-DLL String Verwendung Allgemeine Java-Themen 2
A String auf Zahlen überprüfen Allgemeine Java-Themen 5
N String Array Eingabe Allgemeine Java-Themen 6
MiMa Datum von String zu LocalDateTime Allgemeine Java-Themen 8
W String -> byte[] -> String - Sieht jemand was ich nicht sehe? Allgemeine Java-Themen 10
R char aus String entfernen Allgemeine Java-Themen 10
LimDul Mittels Streams aus Strings A B C den String A, B und C machen Allgemeine Java-Themen 12
M Programm erkennt String aus .txt Datei nicht Allgemeine Java-Themen 3
P einen public <Optinal String> in einer anderen Klasse mit einem Int vergleichen Allgemeine Java-Themen 2
S Ini Text aus String parsen Allgemeine Java-Themen 1
T String-Manipulation beim Ablauf in Eclipse und als JAR-File Allgemeine Java-Themen 8
M String lässt sich nicht Zusammenfügen Allgemeine Java-Themen 10
Drachenbauer Wie kann ich das Wort "concrete" in einem String durch ein anderes Wort ersetzen lassen? Allgemeine Java-Themen 5
R Schlüsselworte "Throw new exception" gibt nicht den String als Fehlermeldung aus Allgemeine Java-Themen 2
R Variablen String mit split-Funktion aufteilen Allgemeine Java-Themen 7
F Datei in String-Array einlesen Allgemeine Java-Themen 8
S Marker aus String ermitteln Allgemeine Java-Themen 5
T Objekt mit String und Int aus TxT Datei erstellen Allgemeine Java-Themen 23
M Bei String.format ein Komma statt einem Punkt ausgeben lassen Allgemeine Java-Themen 1
S MSSQL Exception & Connection String Allgemeine Java-Themen 19
B Bei Email: FW / AW... - Hilfe bei String suche Allgemeine Java-Themen 21
J String - Vergleiche Allgemeine Java-Themen 7
K Aus String zwei Jahreszahlen auslesen Allgemeine Java-Themen 18
Drachenbauer Wie kann eine vorgegebene Farbe über einen String erkannt werden? Allgemeine Java-Themen 11
G CSV in String Allgemeine Java-Themen 7
P String-Verschlüsselung - Frage zur Sicherheit Allgemeine Java-Themen 21
K Methodenaufruf mit String / String zu Objekt konvertieren Allgemeine Java-Themen 8
D Erste Schritte Fehler mit negativen und 0 Zahlen im String Allgemeine Java-Themen 6
Xge Replace x Zeichen aus String Allgemeine Java-Themen 2
coolian warum bekomme ich ein string index out of bounds exception Allgemeine Java-Themen 17
F In String 2 Buchstaben vertauschen Allgemeine Java-Themen 2
J Class Decompile als String (Procyon) Allgemeine Java-Themen 2
I Datentypen String in class sicher verwahren Allgemeine Java-Themen 17
J Falls der String ein "X" beinhaltet Allgemeine Java-Themen 2
T String mehrere Worte Allgemeine Java-Themen 2
D String Groß-/Kleinschreibung Allgemeine Java-Themen 2
D String und Klassenvariable Allgemeine Java-Themen 6
Aruetiise Funktion(y = mx+n) in String speichern und berechnen Allgemeine Java-Themen 9
C String in Objektnamen umwandeln Allgemeine Java-Themen 3
E Variablen Aus .txt ausgelesener string mit if() überprüfen? Allgemeine Java-Themen 2
L String-Schema-Aufspaltung Allgemeine Java-Themen 2
E String in Zahl umwandeln, ohne Befehl Integer.parseInt Allgemeine Java-Themen 3
L String splitten und multiplizeren Allgemeine Java-Themen 10
G String mit umbekannter länge splitten. Allgemeine Java-Themen 2
S Einzigartigen String in Datenbank finden und löschen Allgemeine Java-Themen 23
A Byte zu String Allgemeine Java-Themen 4
B Von String zu <Objekt> ||Speichern/Laden Allgemeine Java-Themen 17
T Komplexitätsoptimierung String vergleich Allgemeine Java-Themen 4
heinz ketchup String im JLabel ausgeben und erneuern Allgemeine Java-Themen 6
S Input/Output Beste Möglichkeit einen String in einen Datei zu Schreiben Allgemeine Java-Themen 2
V Eingegeben String Splitten und in Integer umwandeln Allgemeine Java-Themen 2
L Decrypt String Allgemeine Java-Themen 1
X Variablen AtmicLong größer als String ? Allgemeine Java-Themen 4
S String literal und Referenzvariablen Allgemeine Java-Themen 6
J Datentypen Absätze mit String im Word Dokument Allgemeine Java-Themen 3
D "Paste" String doppelt Allgemeine Java-Themen 14
E String Frage Allgemeine Java-Themen 9
T String aus While Schleife für ganze Klasse sichtbar machen Allgemeine Java-Themen 5
D JSON to String Allgemeine Java-Themen 31
M String automatisch in nächste Zeile umbrechen (Graphics) Allgemeine Java-Themen 6
U Methoden Algorithmus MergeSort String [ ] array sortieren programmieren Allgemeine Java-Themen 17
T Swing Font String Pixellänge Allgemeine Java-Themen 1

Ähnliche Java Themen

Neue Themen


Oben