Heim >Java >javaLernprogramm >Warum schreibt mein BufferedWriter nicht alle Daten in die Ausgabedatei?

Warum schreibt mein BufferedWriter nicht alle Daten in die Ausgabedatei?

Patricia Arquette
Patricia ArquetteOriginal
2024-12-18 00:46:10153Durchsuche

Why Isn't My BufferedWriter Flushing All Data to the Output File?

BufferedWriter löscht Daten nicht in die Ausgabedatei

Problem:

Ein Java-Programm versucht, CSV-Daten in SQL-Befehle umzuwandeln hat Probleme mit der Ausgabedatei. Nicht alle in BufferedWriter geschriebenen Daten erscheinen in der Ausgabedatei.

Details:

Das Programm liest eine CSV-Datei mit über 10.000 Zeilen und generiert SQL-Anweisungen zum Einfügen der Daten in eine Tabelle. Allerdings wird die Ausgabedatei mittendrin abgeschnitten, da in der letzten unvollständigen Anweisung ein Teil eines Werts fehlt.

Code:

// ...
while((line = in.readLine())!= null)
{
    String[] esa = line.split(",");
    sqlstr = "insert into nyccrash values ("+esa[0]+", "+esa[1]+", "+esa[2]+", "+esa[3]+", "+esa[4]+", "+esa[5]+", "+esa[6]+");\n";
    out.write(sqlstr);
}
// ...

Lösung:

Das Problem entsteht, weil der Ausgabepuffer während des Schreibvorgangs nicht geleert wird. Die Standardpuffergröße für BufferedWriter beträgt 8192 Zeichen und reicht aus, um mehrere Zeilen aufzunehmen. Nachdem der Puffer voll ist, werden Daten nicht in die Datei geschrieben, bis der Puffer manuell geleert wird.

Um sicherzustellen, dass alle Daten in die Ausgabedatei geschrieben werden, ist es notwendig, den OutputStream explizit zu schließen, der alle verbleibenden Daten löscht Daten im Puffer:

out.close();

Das Schließen des Ausgabestreams garantiert, dass alle Daten, einschließlich der Teilanweisung, in die Datei geschrieben werden, bevor das Programm beendet wird.

Das obige ist der detaillierte Inhalt vonWarum schreibt mein BufferedWriter nicht alle Daten in die Ausgabedatei?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn