Threads mit Argument?

Status
Nicht offen für weitere Antworten.

nabla

Mitglied
Hi,

ich moechte eine XML Datei einlesen und Objekt fuer Objekt in der Datei parallel (am besten Threads=Anzahl CPUs) bearbeiten. Am Ende der Berechnung in einem Thread wird dann in einem Feld, auf dass alle Threads zugreifen sollen, der Wert um 1 erhoeht (diesen Schreibzugriff, denke ich, muss man locken). Dieses Feld ist in der Klasse, in der auch der berechnende Code ist.

Bis jetzt laeuft das so, dass die XML-Datei geparst wird, und immer wenn ein komplettes Objekt eingelesen wird, wird das Objekt an eine Prozedur weitergegeben. Nun koennte ich diese Prozedur auch run nennen, nur bekommt sie halt kein Argument. Was kann man da machen? Ist die einzige Moeglichkeit, dass man in die Klasse ein temporaeres Objekt einbaut, dass dann immer von run gelesen wird? Aber bekommt man das sicher hin?

btw.: Muss man bei Schleifenvariablen etc. auch aufpassen, dass die Threads sich da nicht ueberschneiden (soll ja gleicher code, nur mit anderen Daten sein)? Wie macht man das?

Ich hoffe, ich konnte mich klar ausdruecken.

Danke
 

hiti

Mitglied
Hallo nabla,

Um in einem Thread arbeiten an Objekten zu verrichten kannst du natürlich das benötigte Objekt per Konstruktor ans Thread-Objekt geben. In der run des Threads bearbeitest du dann dieses übergebene Objekt, oder du rufst nur noch eine Methode des Objekts auf, die die eigentliche Arbeit macht. Wenn du bzgl. Sicherheit gleichzeitige Zugriffe auf Objekte meinst, musst du ein paar Sachen beachten. Z.B. darf ein und das gleicht Objekt nur in einen Thread gegeben werden. Wenn das nicht sichergestellt werden kann muss das Objekt während der Bearbeitung gelockt (synchronisiert) werden.

Zur letzten Frage: Hier musst du unterscheiden, ob es Instanz-Variablen oder Klassen-Variablen (static) sind. In Schleifen verwendet man in der Regel lokale Instanz-Variablen. Diese sind dann nur für dieses Objekt und nur an dieser Stelle 'sichtbar' und gültig. Ein weiteres Objekt hat darauf keinen Einfluss.

Gruss, hiti
 

nabla

Mitglied
Um in einem Thread arbeiten an Objekten zu verrichten kannst du natürlich das benötigte Objekt per Konstruktor ans Thread-Objekt geben. In der run des Threads bearbeitest du dann dieses übergebene Objekt, oder du rufst nur noch eine Methode des Objekts auf, die die eigentliche Arbeit macht. Wenn du bzgl. Sicherheit gleichzeitige Zugriffe auf Objekte meinst, musst du ein paar Sachen beachten. Z.B. darf ein und das gleicht Objekt nur in einen Thread gegeben werden. Wenn das nicht sichergestellt werden kann muss das Objekt während der Bearbeitung gelockt (synchronisiert) werden.

Ok. In meinem Fall habe ich das Gefuehl, dass das etwas kuenstlich wirkt, da ich nun die rechnende Einheit (der Code, der in run muss), getrennt von der Klasse, in der die Ergebnisfelder und anderen benoetigten Groessen sind, halten muss. Letzteres waere fuer alle Datenteile das gleiche. Wird aber vermutlich am besten so sein. Das heisst, ich erzeuge eine Klasse, in der das allgemeine Datenobjekt und der Teil der XML Datei sind.

Zur letzten Frage: Hier musst du unterscheiden, ob es Instanz-Variablen oder Klassen-Variablen (static) sind. In Schleifen verwendet man in der Regel lokale Instanz-Variablen. Diese sind dann nur für dieses Objekt und nur an dieser Stelle 'sichtbar' und gültig. Ein weiteres Objekt hat darauf keinen Einfluss.
Danke, macht Sinn.


Eine Frage noch: kann man dafuer sorgen, dass zum Beispiel nur gleichzeitig 4 threads gleichzeitig laufen? Ein Grund, warum ich die XML Datei zerlegen muss, ist, dass sie viel zu gross fuer den Speicher ist... Klappt das mit newFixedThreadPool(4) und packt alle threads dort rein und er arbeitet immer 4 gleichzeitig ab? Problem ist, dass das nicht genau das ist, was ich brauche, weil ich mit dem "Hauptthread", also mit dem Einlesen, warten muss, wenn zu viele threads noch nicht bearbeitet sind.

Danke!
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
H Nutzt Eclipse alle CPU-Threads beim Ausführen von Java-Programmen? Java Basics - Anfänger-Themen 4
C Threads und Swing Java Basics - Anfänger-Themen 9
berserkerdq2 Wo finde ich in der Java Api die Notation zu Threads bezüglich Synchronized? Java Basics - Anfänger-Themen 14
berserkerdq2 Findet eine parallele Verarbeitung in Java bei Threads erst statt, wenn man die Methoden auch synchronized? Und wie sieht bei Conditions aus? Java Basics - Anfänger-Themen 8
B Monitor als Schranke von Threads Java Basics - Anfänger-Themen 20
W Threads Alphabet Java Basics - Anfänger-Themen 20
H Threads Anfänger Java Basics - Anfänger-Themen 17
1 Threads parallel laufen Java Basics - Anfänger-Themen 11
B Threads Problem mit mehreren Threads Java Basics - Anfänger-Themen 38
M Threads Java Basics - Anfänger-Themen 12
L Threads Synchronisierung zwischen threads Java Basics - Anfänger-Themen 4
M Threads Java Basics - Anfänger-Themen 2
A Threads Java Basics - Anfänger-Themen 9
A Threads Java Basics - Anfänger-Themen 13
A Threads und .join Java Basics - Anfänger-Themen 14
W Threads starten Java Basics - Anfänger-Themen 2
X Threads Zwei Threads, aber doppelte Ausgabe verhindern (synchronized) Java Basics - Anfänger-Themen 54
J Wieviele threads? Java Basics - Anfänger-Themen 9
J Problem bei seriellem Start von Threads Java Basics - Anfänger-Themen 11
O Threads Java Basics - Anfänger-Themen 2
L Buchungssystem und Threads Java Basics - Anfänger-Themen 2
O Threads - Synchronize(), join(), wait(), notify(), yield() Java Basics - Anfänger-Themen 6
L Klassen NFC Reader und JavaFx Problem -> threads? Java Basics - Anfänger-Themen 2
A Kommunikation zwischen nebenläufigen Threads Java Basics - Anfänger-Themen 4
S Gemeinsame Ressource und Mehrfachinstanziierung von Threads Java Basics - Anfänger-Themen 16
S Verklemmung Threads Java Basics - Anfänger-Themen 11
B Threads 2 Threads gleichzeitig laufen lassen Java Basics - Anfänger-Themen 1
M Threads Threads laufen sequenziell, statt gleichzeitig. Java Basics - Anfänger-Themen 9
M Threads run Methode Java Basics - Anfänger-Themen 4
javajoshi mehrere Threads: Methoden zentral unterbringen Java Basics - Anfänger-Themen 8
javajoshi Problem mit zwei Threads und Arrays (Runnable) Java Basics - Anfänger-Themen 12
L Threads Mit Threads JLabel ändern! Java Basics - Anfänger-Themen 2
K Matrixen berechnen nach Worker Master Paradigma mit Threads Java Basics - Anfänger-Themen 4
S Kleine Frage zu Threads Java Basics - Anfänger-Themen 3
M Mit 2 Threads eine Zahl hochzählen Java Basics - Anfänger-Themen 13
T Threads Synchronisieren Java Basics - Anfänger-Themen 6
D Frage Threads Java Basics - Anfänger-Themen 6
Z Threads Executor Framework - Aufgabe auf n Threads aufteilen Java Basics - Anfänger-Themen 10
Z Threads Threads - Zugriff auf Ressourcen ohne(Lock, Synchronized) Java Basics - Anfänger-Themen 2
kilopack15 Verständnisfrage zur Verwendung von notify() bei Threads Java Basics - Anfänger-Themen 2
kilopack15 Mehrere Threads in einer Klasse Java Basics - Anfänger-Themen 8
H Threads funktionieren nicht Java Basics - Anfänger-Themen 4
J Aufgabe(Threads) richtig verstanden/implementiert Java Basics - Anfänger-Themen 27
R Threads aufeinander warten lassen? Java Basics - Anfänger-Themen 10
T Threads Durch threads gestartete Prozesse killen Java Basics - Anfänger-Themen 2
J Threads Java Basics - Anfänger-Themen 38
D Alte Klausuraufgabe Threads Java Basics - Anfänger-Themen 10
A Threads Threads bestimmte Aufgaben zuweisen... Java Basics - Anfänger-Themen 3
R Threads in JavaFX Java Basics - Anfänger-Themen 3
E Threads Doppelte Threads beenden Java Basics - Anfänger-Themen 4
F Sicheres Zurückmelden aus Threads Java Basics - Anfänger-Themen 0
G Threads zum Thema Threads??? null Ahnung Java Basics - Anfänger-Themen 4
Q Threads Threads in Swing Anwendungen Java Basics - Anfänger-Themen 5
J ConcurrentCalculation Multi Threads in Java Java Basics - Anfänger-Themen 3
P Threads Trotz Threads wird nur 1 Prozessorkern ausgelastet Java Basics - Anfänger-Themen 7
M "restartable" threads Java Basics - Anfänger-Themen 11
M Threads - summieren Java Basics - Anfänger-Themen 13
W Klassen Variable einer anderen Klasse ändern (Threads) Java Basics - Anfänger-Themen 3
E Threads - Programm analysieren Java Basics - Anfänger-Themen 2
E join() bei zwei Threads Java Basics - Anfänger-Themen 2
T Threads Threads richtig synchronisieren Java Basics - Anfänger-Themen 3
D [Concurrency/Threads] Code Umsetzung Schriftlich Java Basics - Anfänger-Themen 2
D Threads Java Basics - Anfänger-Themen 4
M Threads nio Dateien kopieren, Threads und Gui Java Basics - Anfänger-Themen 0
N Verweise auf Variablen in verschiedenen Threads Java Basics - Anfänger-Themen 4
T Java-Threads Java Basics - Anfänger-Themen 0
G Moving Objects with Threads (implements Runnable) Java Basics - Anfänger-Themen 1
F Threads funktionieren auf JPanel nicht Java Basics - Anfänger-Themen 1
M Problem mit Threads Java Basics - Anfänger-Themen 11
M Threads - wo gehören sie hin? Java Basics - Anfänger-Themen 3
S 2D-Spiel mit Threads... Java Basics - Anfänger-Themen 3
J Threads Java Basics - Anfänger-Themen 3
F ExecutorService und offene Threads Java Basics - Anfänger-Themen 3
P Threads Threads nicht nebenläufig Java Basics - Anfänger-Themen 7
M Threads nicht nebenleblaufig Java Basics - Anfänger-Themen 2
B Threads parallel zur main Java Basics - Anfänger-Themen 3
M Threads Java Basics - Anfänger-Themen 2
M Threads, zwei methoden gleichzeitig laufen lassen Java Basics - Anfänger-Themen 4
M Threads und Methodenübergreifender Variablezugriff Java Basics - Anfänger-Themen 2
J Wie handle ich Threads am besten? Java Basics - Anfänger-Themen 2
H Threads Java Basics - Anfänger-Themen 10
B synchronized threads Java Basics - Anfänger-Themen 17
E Mehrmaliges Ausführen eines Threads Java Basics - Anfänger-Themen 5
E Threads Verständnisfrage bzgl. Threads und Sleep Java Basics - Anfänger-Themen 2
T Alle Threads .notify() Java Basics - Anfänger-Themen 13
R Threads Verständnisschwierigkeit Java Basics - Anfänger-Themen 2
J Können mehere Threads parallel eine Datei lesen? Java Basics - Anfänger-Themen 4
G Methoden in Threads wandeln Java Basics - Anfänger-Themen 7
H Threads Java Basics - Anfänger-Themen 17
F Java Concurrency - Threads Java Basics - Anfänger-Themen 4
V Threads Threads synchronisieren Java Basics - Anfänger-Themen 4
T Threads Join() = Block? oO Java Basics - Anfänger-Themen 4
J Threads ArrayList Problem bei Threads Java Basics - Anfänger-Themen 3
C Objekte durchschleifen / Threads Java Basics - Anfänger-Themen 2
J Threads stoppen mit interrupt - Frage dazu Java Basics - Anfänger-Themen 7
N Pingen in Threads Java Basics - Anfänger-Themen 9
B Threads benutzen Java Basics - Anfänger-Themen 5
E Allgemein Verständnissfrage zum Ablauf mehrerer Threads Java Basics - Anfänger-Themen 4
S Threads erzeugen Java Basics - Anfänger-Themen 11
K Threads Nur 2 von 3 Threads funktionieren Java Basics - Anfänger-Themen 8

Ähnliche Java Themen

Neue Themen


Oben