Mehrere Threads schreiben in eine Datei

isowiz

Mitglied
Ich habe mehrere Threads, die alle in die selbe Datei (csv) schreiben. Wie kann ich diesen Dateizugriff am besten programmieren?

Wäre es eine gute Lösung, einen eigenen Thread zu machen der als einziger in die Datei schreibt (wobei ich nicht weiß, wie ich Informationen zwischen den Threads austauschen kann)?
Oder ist es besser, eine statische synchronisierte Methode zu nehmen?
Oder sollte man das Problem ganz anders angehen?

Da ich bzgl. Threads noch am Anfang stehe bin ich über jeden Tipp froh :).
 
G

gman

Gast
Hi,

sollen die Threads denn über einen längeren Zeitraum beständig/wiederholt in die Datei reinschreiben,
oder "berechnen" die irgendwas und schreiben dann ihre Ergebnisse in die Datei?

In ersterem Fall würde ich das vielleicht wie so eine "Producer-Consumer"-Geschichte aufziehen, wobei
die Threads die Producer sind und ein weiterer Thread als Consumer die Ergebnisse der Threads in die
Datei schreibt. Für diesen Ansatz brauchst du halt einen Speicher in den die Producer reinschreiben
und aus dem der Consumer´lesen kann. Der Zugriff auf diesen Speicher (sowas wie List<String> bei
der jedes Element eine Zeile der CSV-Datei werden soll) müsste dann synchronisiert werden. Ich
glaube da bietet sich vielleicht die ArrayBlockingQueue an. Wenn keiner der Producer-Threads was
in den Speicher geschrieben hat, müsste der Lesezugriff natürlich blockieren.

Im zweiten Fall kannste ja einfach die Ergebnisse der Threads synchronisiert in eine gemeinsame
List<String> packen und danach komplett in die Datei schreiben.

Hoffe das hilft dir ein wenig weiter ;)
 

Wortraum

Bekanntes Mitglied
Wäre es eine gute Lösung, einen eigenen Thread zu machen der als einziger in die Datei schreibt (wobei ich nicht weiß, wie ich Informationen zwischen den Threads austauschen kann)?
Ich finde das schön klar. Nur dieser eine Thread öffnet die Datei, nur dieser eine schreibt, nur dieser eine schließt.

Wie gman schon schrieb, ist das ein klassisches Erzeuger‐Verbraucher‐Problem. Dazu findest Du viele Informationen über Google, einiges davon vermutlich recht theoretischer Natur, aber so grundlegend mußt Du in Java nicht herangehen; hier kannst Du die Klasse LinkedBlockingQueue verwenden.

Mit LinkedBlockingQueue können beliebig viele Threads Daten an die Warteschlange anfügen und beliebig viele diese Daten entnehmen. Wie der Name schon sagt, blockiert ein Thread, der der Warteschlange etwas entnehmen möchte, falls keine neuen Daten da sind. Sobald welche da sind, entnimmt er sie automatisch und macht weiter. Du mußt Dich also weder darum kümmern, daß die Threads synchronisiert werden, noch darum, daß Threads aufgeweckt werden, sobald neue Daten verfügbar sind.

Edit: Oh, ich habe ganz übersehen, daß gman bereits die ArrayBlockingQueue erwähnte. Die kann man natürlich auch verwenden.
 
Zuletzt bearbeitet:

isowiz

Mitglied
Vielen Dank für Eure Antworten. Das hilft mir sehr. Jetzt weiß ich, in welche Richtung ich suchen muss :).

Zur Info wie ich mir das vorstelle:
- Quell-csv Datei (100.000 Einträge)
- Ziel-csv Datei (100.000 berechnete Ergebnisse)

1. Ein Eintrag wird aus Quelle entnommen
2. neuer Thread führt Berechnung durch
3. Ergebnis in Zieldatei schreiben
4. Thread beendet

Und das ganze eben parallel. Und wenn ein Eintrag an Stelle n entnommen wird muss das Ergebnis in der Zieldatei auch wieder an Stelle n geschrieben werden.
 
G

gman

Gast
wenn ein Eintrag an Stelle n entnommen wird muss das Ergebnis in der Zieldatei auch wieder an Stelle n geschrieben werden

Hm, ist natürlich doof wenn ein Thread etwas länger braucht und dann die anderen Threads
darauf warten müssen, weil sonst die Reihenfolge der Ergebnisse durcheinander kommt.
Sieht wohl so aus als müsstest du die Ergebnisse der Threads zwischenspeichern und dann
sicherstellen das sie in der richtigen Reihenfolge geschrieben werden. Dafür müsstest du
natürlich auch die Information speichern welcher Zeile ein Datensatz entspricht.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
javajoshi mehrere Threads: Methoden zentral unterbringen Java Basics - Anfänger-Themen 8
kilopack15 Mehrere Threads in einer Klasse Java Basics - Anfänger-Themen 8
N Mehrere Threads starten/stoppen Java Basics - Anfänger-Themen 4
M Mehrere Threads nutzen --> run() schneller als start(), Warum? Java Basics - Anfänger-Themen 3
F Collections ConcurrentModificationException in ArrayList, mehrere Threads Java Basics - Anfänger-Themen 7
V ObjectOutputStream/ObjectInputStream eines Objectes fuer mehrere Threads Java Basics - Anfänger-Themen 6
J Übergabe einer ArrayList an mehrere Threads Java Basics - Anfänger-Themen 3
N mehrere Threads erstellen Java Basics - Anfänger-Themen 2
G Herausfinden, wann mehrere Threads abgeschlossen sind Java Basics - Anfänger-Themen 3
V mehrere Threads starten + Endlosschleife Java Basics - Anfänger-Themen 3
T Mehrere Threads durch Pipes verbinden Java Basics - Anfänger-Themen 9
B auf mehrere Threads warten Java Basics - Anfänger-Themen 3
K Mehrere Werte in einem Switch Case parallel überprüfen Java Basics - Anfänger-Themen 23
S HashMap mehrere Keys zu einem Value Java Basics - Anfänger-Themen 3
T Mehrere if bedingungen ohne & Java Basics - Anfänger-Themen 2
I JPA Query für mehrere Klassen Java Basics - Anfänger-Themen 3
MiMa Java Doc mehrere Return Parameter Java Basics - Anfänger-Themen 11
javaBoon86 Array mehrere Dimensionen Java Basics - Anfänger-Themen 10
Buroto Klassen Mehrere .txt Datein verbienden und anschließend auslisten Java Basics - Anfänger-Themen 10
S mehrere TreeSets so speichern, dass man sie miteinander vergleichen kann Java Basics - Anfänger-Themen 1
P Zähler Variable für mehrere Objekte Java Basics - Anfänger-Themen 6
M Mehrere Daten/ Variablen Speichern Java Basics - Anfänger-Themen 9
C mehrere JPanel in ein JFrame bringen Java Basics - Anfänger-Themen 9
L Beim Java Programmstart, mehrere Parameter über die Kommandozeile übergeben Java Basics - Anfänger-Themen 9
D mehrere Berechnungen in einer Methode Java Basics - Anfänger-Themen 9
U Kann man bei Java gleich mehrere Bedingungen prüfen in der If, aber in einem "Satz"? Java Basics - Anfänger-Themen 1
Kotelettklopfer Mehrere Projekte in einem Git verwalten Java Basics - Anfänger-Themen 10
I JAX-RS Mehrere Parameter in Query Java Basics - Anfänger-Themen 3
M mehrere Rückgabenwerte aus Methode Java Basics - Anfänger-Themen 7
A Input/Output Mehrere Csv-Dateien einlesen Java Basics - Anfänger-Themen 2
R Mehrere Buchstaben aus einem String entfernen Java Basics - Anfänger-Themen 1
TimoN11 Java - Eine oder mehrere Eingaben möglich machen Java Basics - Anfänger-Themen 6
M Mehrere Datenbank zugriffe über tomee.xml regeln? Java Basics - Anfänger-Themen 1
S Mehrere Probleme im Code Java Basics - Anfänger-Themen 7
Ich lerne Java. Methoden Mehrere Methoden mit Punkt Java Basics - Anfänger-Themen 45
M Ausgabe einer Liste welche mehrere Stacks enthält Java Basics - Anfänger-Themen 3
D OOP- Eine Klasse in mehrere Klassen aufteilen Java Basics - Anfänger-Themen 7
F Mehrere Server Sockets in einer Anwendung Java Basics - Anfänger-Themen 9
T DoWhile Schleife über mehrere Mothoden Java Basics - Anfänger-Themen 5
B Methoden Mehrere ähnliche Methoden zusammenfassen Java Basics - Anfänger-Themen 24
E Mehrere Eingabezeilen gleichzeitig einlesen Java Basics - Anfänger-Themen 7
C Mehrere Zufallswerte Java Basics - Anfänger-Themen 4
M Dijkstra Algorithmus in Graphen auf mehrere verschiedene Knoten anwenden lassen Java Basics - Anfänger-Themen 11
R Error, wenn mehrere Clients gleichzeitig die Verbindung beenden Java Basics - Anfänger-Themen 16
F Mehrere Exceptions in einem Catch-Block abfangen Java Basics - Anfänger-Themen 12
O Datei in mehrere kleine Dateien umwandeln Java Basics - Anfänger-Themen 47
Henri Mehrere Ordner umbenennen Java Basics - Anfänger-Themen 11
E Mehrere Arrays addieren mit Übertrag Java Basics - Anfänger-Themen 13
B mehrere Werte mit scanner und while schleife einlesen, max berechnen bzw addieren Java Basics - Anfänger-Themen 2
J Mehrere paintComponenten in einem Programm Java Basics - Anfänger-Themen 0
F Mehrere Buttons mit einem ActionListener abdecken Java Basics - Anfänger-Themen 24
B Jeweils den Parent bekommen -> mehrere Ebenen Java Basics - Anfänger-Themen 2
M Erste Schritte Mehrere eingaben in einer Line vergleichen (if equals...) Java Basics - Anfänger-Themen 6
L Mehrere Jars im Unterordner Java Basics - Anfänger-Themen 2
L LibGDX - mehrere Screens Java Basics - Anfänger-Themen 1
J Sudoku mehrere Lösungen Java Basics - Anfänger-Themen 29
F Mehrere Instanzen der Klasse A EINER Instanz der Klasse B übergeben Java Basics - Anfänger-Themen 3
T Mehrere JFrames gleichzeitig öffnen Java Basics - Anfänger-Themen 6
O Erste Schritte Scanner mehrere male benutzen (Konsole) Java Basics - Anfänger-Themen 7
S mehrere If Bedingungen Java Basics - Anfänger-Themen 5
F Mehrere Zeilen zu einer Zeile zusammenfügen und in eine Datei schreiben Java Basics - Anfänger-Themen 1
B Mehrere Zahlen speichern Java Basics - Anfänger-Themen 60
M mehrere extends? Java Basics - Anfänger-Themen 19
N Datei Zeilenweise einlesen, Ausgabe mehrere Arrays Java Basics - Anfänger-Themen 7
C ButtonController löst mehrere Methoden aus Java Basics - Anfänger-Themen 5
D JPanel mehrere Formen zeichnen Java Basics - Anfänger-Themen 5
B Timer mehrere Male ausführen Java Basics - Anfänger-Themen 4
F mehrere eingegebene Zahlen mit Zahlen von 1-9 multiplizieren Java Basics - Anfänger-Themen 18
F Mehrere Konstruktoren? Wofür? Java Basics - Anfänger-Themen 21
J Mehrere Eingabefelder programmiert (Zeigt Fehler an) Java Basics - Anfänger-Themen 6
Jinnai4 Mehrere Textfelder überprüfen Java Basics - Anfänger-Themen 16
N Mehrere Forms auf einem Panel Java Basics - Anfänger-Themen 6
Tommy Nightmare Variable auf mehrere Ungleichheiten prüfen Java Basics - Anfänger-Themen 18
D Mehrere Objekte in ein Objekt zusammenfassen Java Basics - Anfänger-Themen 16
D Input/Output Mehrere Befehle nacheinander ausführen Java Basics - Anfänger-Themen 20
K Mehrere Objekte anlegen Java Basics - Anfänger-Themen 23
N Integers aus Textdatei auslesen und mehrere Arrays erstellen Java Basics - Anfänger-Themen 9
S Verständnis - Frage mehrere SQL Statements in While Schleife Java Basics - Anfänger-Themen 0
J MVC Pattern, mehrere Controller/Views/Models Java Basics - Anfänger-Themen 0
J Mehrere IF Anweisungen und dazugehörige ELSE Java Basics - Anfänger-Themen 6
I Klassen Mehrere Java Klassen in einer .java Datei Java Basics - Anfänger-Themen 7
V Mehrere Dateien aus JFileChooser in eine ArrayList speichern Java Basics - Anfänger-Themen 2
F Mehrere Konstruktoren Java Basics - Anfänger-Themen 10
A Mehrere Radiobuttons Java Basics - Anfänger-Themen 3
B Klassen Mehrere Objekte mit Schleife erstellen - How? Java Basics - Anfänger-Themen 1
T Mehrere Methoden in der main-Methode verknüpfen und aufeinander anwenden Java Basics - Anfänger-Themen 2
V OOP Aufnahme von Dreiecken in ein/mehrere Objekte Java Basics - Anfänger-Themen 0
Q OOP Mehrere Instanzen auf ein Feld Java Basics - Anfänger-Themen 13
C Klasse auf mehrere Objekte zugreifen lassen Java Basics - Anfänger-Themen 26
G Mehrere If-else-Sätze der Reihe nach durchlaufen lassen Java Basics - Anfänger-Themen 2
K Mehrere String.valueOf() kürzer schreiben / "packen"? Java Basics - Anfänger-Themen 2
F String mehrere male ausgeben? Java Basics - Anfänger-Themen 4
H wie mehrere variablen in einfacher for-schleife? Java Basics - Anfänger-Themen 2
H möglichkeiten für for-schleife? (mehrere ausgangsvariablen?) Java Basics - Anfänger-Themen 9
M PdfBox - mehrere Formularseiten Java Basics - Anfänger-Themen 2
Z Mehrere XML-Dateien zu einer zusammenfügen Java Basics - Anfänger-Themen 3
M GUI- mehrere Komponenten auf Container adden Java Basics - Anfänger-Themen 2
I Erste Schritte Resource Bundle - Alles in einem File oder mehrere? => Faktor Performance Java Basics - Anfänger-Themen 2
F Methoden split() - Mehrere Zeichen Java Basics - Anfänger-Themen 5
F Erste Schritte Mehrere nextInt() Eingaben nebeneinander ausgeben Java Basics - Anfänger-Themen 12

Ähnliche Java Themen

Neue Themen


Oben