Threads anhand eines Tokens abarbeiten

Status
Nicht offen für weitere Antworten.

akkie

Mitglied
Hallo,

Ich habe ein MessageBean welches Nachrichten von einem Chat-Client erhält. Bis jetzt verarbeite ich die Nachrichten asynchron. Ich möchte das Verhalten aber ändern. Es sollen immer jeweils die Nachrichten zu einer SenderId(token) asynchron und alle anderen synchron verarbeitet werden.

Sagen wir mal wir haben 3 User. Von User 1 kommen zehn Nachrichten, von User 2 kommen fünf Nachrichten und von User 3 kommt eine Nachricht an. So sollen die Nachrichten von User 1 alle hintereinander(synchronized) verarbeitet werden. Parallel dazu sollen von User 2 alle hintereinander(synchronized) verarbeitet werden. Und die Nachricht von User 3 soll genauso parallel abgearbeitet werden.

Lässt sich das irgendwie bewerkstelligen?

Bis jetzt sieht das ganze so aus:
Java:
synchronized(queue) {
	queue.offer((TextMessage) msg);
	TextMessage txtMsg = queue.poll();
	MessageService msgService = new MessageService();
	msgService.handleMessage(
		this.getType(txtMsg), 
		this.getSenderId(txtMsg), 
		this.getRecipientId(txtMsg), 
		this.getText(txtMsg),
		this.getForward(txtMsg)
	);
}

Mfg Akkie
 
S

SlaterB

Gast
es ist nicht so richtig klar, wohin das hinführt,

synchronized, in Java für den sicheren Umgang bei Nebenläufigkeit, hat nicht unbedingt was mit synchron/ asynchron zu tun

synchron ist ein normaler Methodenaufruf: der Aufrufer muss warten, bis dieser fertig bearbeitet ist,
und sei es, dass die aufgerufene Methoden eine sleep-Schleife enthält, bis irgend anderer Thread irgendwas fertig bearbeitet hat

asynron bedeutet z.B., das die Arbeit in einer Queue kommt und der Aufrufer gleich wieder weitermachen kann,
aus freien Stücken vielleicht selber alle x Sekunden nachschaut, ob der Auftrag erledigt ist, bzw. besser noch die Gegenseite meldet sich, wenn sie fertig ist,

all das kann gerne programmieren, besteht dazu eine Frage?
 

akkie

Mitglied
Hi

Mein Problem hier ist ja das ich eine Mischung aus beiden Varianten will. Ein Teil soll synchron und eine teil soll asynchron abgearbeitet werden.

Mein vorgehen wäre eine Queue zu erstellen in die ich anhand eines Tokens, Nachrichten speichere. Wenn eine neue Nachricht ankommt würde ich die Queue fragen ob den schon eine Nachricht mit dem selben Token gespeichert ist. Wenn ja muss gewartet werden bis die Queue frei ist. Wenn kein eintrag existiert kann die Message gleich abgearbeitet werden. Den Zugriff auf die Queue muss ich ja aber Threadsicher programmieren. Wenn ich hier jetzt einen synchronized Block darum lege kann ja jeder Thread nur nacheinander abgearbeitet werden. Und das möchte ich ja vermeiden.

Oder sehe ich das Falsch???:L

Mfg Akkie
 
S

SlaterB

Gast
synchronized ist nur für den Zugriff nötig, der in paar ms abgearbeitet werden kann,
falls eine Methode dann länger wartet, bis was frei ist, muss das nicht die ganze Zeit im synchronized-Block sein,

wenn man Thread.sleep() verwendet, dann eben außerhalb eines derartigen Blocks schlafen,

mit wait/ notify geht es noch komfortabler ohne Wechsel
 

faetzminator

Gesperrter Benutzer
Du kannst [c]Map<Token, Queue<TextMessage>>[/c] o.ä. machen und für jedes Token eine eigene Queue verwenden.
 

akkie

Mitglied
Du kannst [c]Map<Token, Queue<TextMessage>>[/c] o.ä. machen und für jedes Token eine eigene Queue verwenden.

Die Idee hatte ich gestern auch schon mal, habe es aber nicht hinbekommen.

Das ganze sah in etwa so aus.
Java:
synchronized(map.get(token)) {
    Queue queue = map.get(token);
    queue.offer((TextMessage) msg);
    TextMessage txtMsg = queue.poll();
    MessageService msgService = new MessageService();
    msgService.handleMessage(
        this.getType(txtMsg), 
        this.getSenderId(txtMsg), 
        this.getRecipientId(txtMsg), 
        this.getText(txtMsg),
        this.getForward(txtMsg)
    );
}

Mfg Akkie
 
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