Code 'innerhalb' des synchronen Bereichs einer BlockingQueue ausfuehren..?

sirbender

Top Contributor
Hallo,
eine BlockingQueue ist ja threadsafe bzgl. Operationen wie add() und take().
Nun wuerde ich fuer einige Experimente die ich damit mache gerne ausgeben koennen wie gross z.B. die Queue ist usw. nachdem ich z.B. ein add() ausgefuehrt habe.

Leider ist das alles nicht 'atomic'. Soll heissen, zwischen meinem add() und System.out.println(queue.size()) kann eine Menge passieren (eine anderer Thread fuegt der Queue Elemente hinzu bzw. entfernt diese). Ich weiss also nicht wie gross die Queue unmittelbar vor bzw. nach dem add() war.

Kann ich irgendwie Code 'uebergeben' der vor bzw. nach dem add() ausgefuehrt wird, allerdings innerhalb des 'Locks' des add() Aufrufs?

Bzw. gibt es eine andere Loesung fuer dieses Problem?
 

mrBrown

Super-Moderator
Mitarbeiter
Ich würde mal behaupten, das wird so nicht möglich sein.

uU Decorator-Pattern mit eigener Synchronisation nutzen?
 

sirbender

Top Contributor
Ich hab mal kurz ein bischen minimalen Testcode geschrieben auf dessen Grundlage man diskutieren kann.
Wie hast du dir das mit dem Decorator-Pattern und eigener Synchronisation vorgestellt?

Ich habe im Code markiert welchen Bereich ich synchron ausfuehren will.

Vielen Dank!


Java:
package exp;

import java.util.concurrent.BlockingQueue;
import java.util.concurrent.LinkedBlockingQueue;

/**
 * Usage example, based on a typical producer-consumer scenario. Note that a
 * BlockingQueue can safely be used with multiple producers and multiple
 * consumers.
 */
public class BlockingCueExample {
 
    static abstract class Producer<T> implements Runnable {
      private final BlockingQueue<T> queue;
      Producer(BlockingQueue<T> q) { queue = q; }
      public void run() {
        try {
                while (true) {
                    T produce = produce();
                   
                    // Wie kann ich sicher gehen, dass dieser Bereich als Block ausgefuehrt wird und zwischendrin kein Thread auf die Queue zugreift?

                    // Anfang
                   
                    System.out.println("p: " + produce + "[" + Thread.currentThread() + "]");
                    System.out.println(queue.size());
                    queue.put(produce);
                    System.out.println("p: " + produce + "[" + Thread.currentThread() + "]");
                    System.out.println(queue.size());
                   
                    // Ende
                }
        } catch (InterruptedException ex) { System.out.println("... handle ...");}
      }
      abstract T produce() throws InterruptedException;
    }

    static class Consumer<T> implements Runnable {
      private final BlockingQueue<T> queue;
      Consumer(BlockingQueue<T> q) { queue = q; }
      public void run() {
        try {
          while (true) { consume(queue.take()); }
        } catch (InterruptedException ex) { System.out.println("... handle ..."); }
      }
      void consume(T x) { System.out.println("c: " + x + "[" + Thread.currentThread() + "]"); }
    }

     
    public static void main(String[] args) {
        BlockingQueue<String> q = new LinkedBlockingQueue<String>();
        Producer<String> p1 = getProducer(q);
        Producer<String> p2 = getProducer(q);
        Consumer<String> c1 = new Consumer<String>(q);
        Consumer<String> c2 = new Consumer<String>(q);
        new Thread(p1).start();
        new Thread(p2).start();
        new Thread(c1).start();
        new Thread(c2).start();   
    }

    private static Producer<String> getProducer(BlockingQueue<String> q) {
        return new Producer<String>(q) {
            @Override
            String produce() throws InterruptedException {
                long timeMillis = System.nanoTime();
                Thread.sleep(500);
                return "" + timeMillis;
            }
        };
    }
}
 

tommysenf

Top Contributor
Java:
      public void run() {
        try {
                while (true) {
                    T produce = produce();
                
                    // Wie kann ich sicher gehen, dass dieser Bereich als Block ausgefuehrt wird und zwischendrin kein Thread auf die Queue zugreift?

                   
                   synchronized(queue) {
                
                             System.out.println("p: " + produce + "[" + Thread.currentThread() + "]");
                             System.out.println(queue.size());
                             queue.put(produce);
                             System.out.println("p: " + produce + "[" + Thread.currentThread() + "]");
                             System.out.println(queue.size());
                       }
                
                    // Ende
                }
        } catch (InterruptedException ex) { System.out.println("... handle ...");}
      }
 

mrBrown

Super-Moderator
Mitarbeiter
Und an der nächsten stelle vergisst man den synchronized-block und alles geht kaputt ^^


Ja, aber konkret mit dem aktuellen Beispiel von mir kann ich mir gerade nicht vorstellen wie die Sync. ablaufen muss?

Du implementierst selber BlockingQueue, in den Methoden synchronisierst du erst über ein eigenes Objekt und in dem Block machst du deine Ausgaben und delegierst weiter. Alternativ fügst du zusätzliche Methoden hinzu, denen du dann zusätzlich Consumer übergeben kannst
 

sirbender

Top Contributor
Ich hatte gehofft, dass es vielleicht eine Implementierung gibt, die fuer alle Methoden von BlockingQueue eine Methode mitdemselben Namen hinzufuegt und diese um zwei Runnables erweitert. Am Ende hat man dann also 2 Methoden und die eine ruft die andere auf mit Runnables auf Null gesetzt:
queue.add(T tobeAdded)
queue.add(T tobeAdded, Runnable executeBefore, Runnable executeAfter)

Ich hab es mir mal angeschaut und ich befuerchte, dass eine sichere Implementierung einer solchen BlockingQueue meine Faehigkeiten uebersteigt.

Waere aber denke ich eine gute Idee sowas zu haben.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
M Unsicher, ob das Code richtig ist Allgemeine Java-Themen 4
MarvinsDepression Unbekanntes Zeichen in fremden Code wirft Fragen auf Allgemeine Java-Themen 4
schemil053 Methoden Code-Verbesserung Allgemeine Java-Themen 2
D Webarchive (war): Code verschleiern Allgemeine Java-Themen 7
D Compiler-Fehler child process exited with code 1 Allgemeine Java-Themen 1
Queenman Interface Mein Microsoft Visual Studio Code zeigt komische Dinge & Menüs an Allgemeine Java-Themen 9
A Clean Code: Variable vs. Methode Allgemeine Java-Themen 8
berserkerdq2 Versteht jemand, was diese beiden Zahlen bei dem IJVM Code zu bedeuten haben? Allgemeine Java-Themen 10
OnDemand Releaseversion Tag in Code Allgemeine Java-Themen 5
ERlK JDA Code funktioniert nicht? Allgemeine Java-Themen 4
F Code auslagern Allgemeine Java-Themen 5
D VBA Code mit Java ausführen möglich? Allgemeine Java-Themen 10
N JAVA-Code mit Grafikfenster zeichnet in Windows, aber nicht Mac. Allgemeine Java-Themen 4
JordenJost Unverständlicher Java code? Allgemeine Java-Themen 21
V Hilfe mit Java Code Allgemeine Java-Themen 4
S Processing Java Code verstehen Allgemeine Java-Themen 4
A code wird nicht ausgeführt Allgemeine Java-Themen 3
B Bitte um Code Erklärung Allgemeine Java-Themen 5
N nicht einsehbarer Fehler im code, kann nicht mehr übersetzten Allgemeine Java-Themen 51
N Regulären Ausdruck in normalen Java-Code umwandeln Allgemeine Java-Themen 12
OnDemand Clean Code oder Allgemeine Java-Themen 5
Noahscript Aus einem byte Array Steuerungszeichen und Code bekommen und ersetzen Allgemeine Java-Themen 3
J Simple Date Format Alternativen bitte um Code Allgemeine Java-Themen 14
AGW in Java-Code plötzlich ein paar Wörter in Rot Allgemeine Java-Themen 2
L Best Practice Auslagerung von Code = Performance Optimierung? Allgemeine Java-Themen 4
H Precompilierten code ansehen Allgemeine Java-Themen 3
R Wo müsste ich im Code eine Änderung vornehmen? Allgemeine Java-Themen 6
L Ausgabe von in Echtzeit ausgeführten Code Allgemeine Java-Themen 9
Drachenbauer Wie kann ich die menge an code reduzieren? Allgemeine Java-Themen 28
Thallius Warum ist dieser Code OS abhängig? Allgemeine Java-Themen 10
S Code Erklärung Allgemeine Java-Themen 21
B Pausem im Code Allgemeine Java-Themen 2
T Java-Quiz Code Fehler Allgemeine Java-Themen 10
L Eclipse Java Code ausführen Allgemeine Java-Themen 18
F Java Code ausführen direkt nach Anmelden in Windows Allgemeine Java-Themen 2
F Code in Klassen bringen Allgemeine Java-Themen 4
S Gibt es eigentlich Java Source Code Interpreter..? Allgemeine Java-Themen 13
J JUnit - Auslassen von Code Allgemeine Java-Themen 25
F Klassen Spaghetti Code Vermeidung Allgemeine Java-Themen 16
C code oder Bibliotheken für 2-Center Problem Allgemeine Java-Themen 4
J Code Page characters darstellen Allgemeine Java-Themen 12
J wie sollte man sinnvoll seinen Code aufteilen Allgemeine Java-Themen 6
I Python Code in Java Code Allgemeine Java-Themen 9
M Java (GUI) Code verdoppeln oder anzeige mehrmals anzeigen? Allgemeine Java-Themen 8
N Wie öffne ich einen runtergeladadenen Code in IntelliJ Allgemeine Java-Themen 3
R Fehler im Code Allgemeine Java-Themen 1
R Fehler im Code Allgemeine Java-Themen 3
O Standard library nativer C code Allgemeine Java-Themen 1
R Wo ist mein Fehler in diesem Code Allgemeine Java-Themen 7
S Java Editor Bekomme bei der Code-Vervollständigung die Zeichen &#8203; Allgemeine Java-Themen 3
N Morse Code decoder Allgemeine Java-Themen 9
O Erste Schritte Benzinverbrauch Code Hilfe Allgemeine Java-Themen 3
S Eclipse exit code 805306369 Allgemeine Java-Themen 1
Pataraca Vererbung Code einbinden Allgemeine Java-Themen 3
Developer_X Website HTML Code von HTTPS URL laden Allgemeine Java-Themen 0
S Wie kann ich eine kleine Stelle in meinem Code mit multiplen Threads abarbeiten..? Allgemeine Java-Themen 20
F Verständlichkeitsproblem bei Java Code?! Allgemeine Java-Themen 2
G Eclipse Eclipse: Unreachable code Allgemeine Java-Themen 16
P Java Android Code in IOS compilieren? Allgemeine Java-Themen 9
C Code vereinfachen Allgemeine Java-Themen 2
T Hilfe bei Code Allgemeine Java-Themen 3
R Java-Code für folgene Aufgabe? Allgemeine Java-Themen 8
Prafy Best Practice Code Refaktorisierung Allgemeine Java-Themen 7
WetWer Was bedeutet/macht ein Exit-Code Allgemeine Java-Themen 1
D Code für bereitgestellte Methoden Allgemeine Java-Themen 1
perlenfischer1984 HTML Code decodieren Allgemeine Java-Themen 2
C ASCII-Code in Java Allgemeine Java-Themen 1
J Java-Code in DLL packen Allgemeine Java-Themen 5
J LWJGL 3 Error Code 1282 Allgemeine Java-Themen 4
0 Code startet nicht (Keine Warnung/Fehlermeldung) Allgemeine Java-Themen 4
A Frage zu meinem Code Allgemeine Java-Themen 2
B Code generierung Velocity Templates Telosys Allgemeine Java-Themen 1
E Fehlermeldung vor dem Programm code Allgemeine Java-Themen 1
B JAVA - mehrere Clienten gleichzeitig starten. Nicht bei Code! Allgemeine Java-Themen 3
Fischkralle Ausführen von fremden Code Allgemeine Java-Themen 14
wolfgang63 Code snipped Software Allgemeine Java-Themen 1
L Eclipse Editieren des Code templates für Override methods Allgemeine Java-Themen 2
J Java code "plugin" fähig machen Allgemeine Java-Themen 4
alderwaran .jar Code Signing, User-Keystore und Fragen dazu Allgemeine Java-Themen 0
Thallius Wie verstecke ich meinen private Key am besten im Code? Allgemeine Java-Themen 10
A Thread: Code paralell ausführen in mehreren Instanzen Allgemeine Java-Themen 1
B NullPointerException - Aber kein Fehler im Code Allgemeine Java-Themen 4
N HTTP response code: 403 Allgemeine Java-Themen 3
D Code bitte mit 19 stelligen Zahlen kompatibel machen Allgemeine Java-Themen 5
D Java Compiler code referencen Allgemeine Java-Themen 0
B Fehler im Java-Code Allgemeine Java-Themen 4
A PHP-Code zu Java-Code Allgemeine Java-Themen 5
M Code läuft unter windows aber nicht unter Linux Allgemeine Java-Themen 6
X Was macht folgender Code!? Allgemeine Java-Themen 6
K Code zu einem Projekt entschluesseln Allgemeine Java-Themen 15
H Java Leistungssteigerung durch Code Anpassung Allgemeine Java-Themen 5
Fab1 Best Practice Vorgehensweise bestehenden Code/Programm verschönern Allgemeine Java-Themen 4
M Code optimieren Allgemeine Java-Themen 7
A jEditorPane Html Datei öffnen (code) Allgemeine Java-Themen 3
S EAN-Code Tabelle für CD's Allgemeine Java-Themen 2
T Code durch eigenes Frame pausieren (ähnlich JDialog) Allgemeine Java-Themen 4
J Erzeugung von Java-Code Allgemeine Java-Themen 2
A Source code analyze Allgemeine Java-Themen 8
N VB Code in Java verwenden Allgemeine Java-Themen 5
P Aktuellen HTML Code auslesen (von JS manipuliert) Allgemeine Java-Themen 3

Ähnliche Java Themen

Neue Themen


Oben