Threads Lock über mehrere Abschnitte in verschiedenen Methoden

Moin,
ich habe das folgende Problem mit Locks:

Ich habe mehrere Methoden und wenn ein kritischer Abschnitt in Methode a() erreicht wird, dann muss auch gleichzeitig ein kritischer Abschnitt in Methode b() "scharf gestellt" werden.
Umgekehrt gilt dies aber nicht!

Ich probiere es am Beispiel deutlich zu machen:

Java:
private static volatile char[]	accectableChars;

public char[] getAccectableChars()
{
    // start passiv-kritischer Bereich
    ...
    // end passiv-kritischer Bereich
   
    return accectableChars;
}

public void setAccectableChars(char[] accectableChars)
{
    // start aktiv-kritischer Bereich
	accectableChars = accectableChars;
    // end aktiv-kritischer Bereich
}
Wenn die set Methode aufgerufen wird, dürfen andere Threads auch nicht auf die get-Methode zugreifen. Wenn aber kein Thread in der set-Methode ist, sollen sie alle parallel auf die get zugreifen.

Meine nicht korrekte Lösung nutzt ein ReentrantLock-Objekt, das in set aktiviert wird und in get mit isLocked() abgefragt wird:

Java:
private final ReentrantLock setCharLock;
private static volatile char[]	accectableChars;

public char[] getAccectableChars()
{
    while(setCharLock.isLocked())
    {
			
    }
    // start passiv-kritischer Bereich
       ...
    // end passiv-kritischer Bereich
		
    return accectableChars;
}

public void setAccectableChars(char[] accectableChars)
{
    // start aktiv-kritischer Bereich
    setCharLock.lock();
		
    accectableChars = accectableChars;

    // end aktiv-kritischer Bereich
    setCharLock.unlock();
}
Mit dieser "Lösung" kann das Problem auftreten, dass Thread 1 im passiv-kritischen Bereich ist, wenn Thread2 den aktiv-kritischen Bereich locked, da Thread1 nur vor dem passiv kritischen Bereich testet, ob der Lock gesetzt ist, er müsste es aber während des ganzen Abschnitts tun und jeder andere Thread müsste mit dem Betreten des aktiv-kritischen Abschnitts warten, bis alle Threads aus dem passiv-kritischen raus sind.

Wie löst man das am saubersten?
 

DrZoidberg

Top Contributor
Sofern du in jeder Methode nur ein einziges mal auf accectableChars zugreifst benötigst du gar keinen Lock. Die Variable als volatile zu deklarieren reicht aus.
Falls du aber doch Locks benötigen solltest, was mit ziemlicher Sicherheit hier nicht der Fall ist, musst du halt auch in getAccectableChars den Lock aktivieren.
acceptable wird übrigens mit p geschrieben.
 
Zuletzt bearbeitet:
Hallo DrZoidberg,
danke für die Antwort. Mein Beispiel war nicht nur orthografisch schlecht gewählt. Ich habe n der set-Methode die Pünktchen weggelassen, in der Realität soll das char-Array eingelesen, verändert und neu gespeichert werden. Z. B. so:
Java:
public void setAccectableChars(char[] accectableCharsLocal)
{
    // start aktiv-kritischer Bereich
    setCharLock.lock();

    for(int i = 0; i < accectableCharsLocal.length; i++)
    {
	AccectableChars.accectableChars[i] = accectableCharsLocal[i] * 2;		
    }

    // end aktiv-kritischer Bereich
    setCharLock.unlock();
}
Jetzt brauch ich natürlich den Lock auch in der get-Methode, nicht dass das statische Array zur Hälfte erneuert ist, wenn es von einem anderen Thread gelesen wird. Da die get-Methode zur set-Methode im Verhältnis 50000:1 aufgerufen wird, ist es aus Performance-Sicht ein Unding, beide generell zu locken. Anscheinend gibt es aber bisher keine andere Möglichkeit, oder?
 

turtle

Top Contributor
So ganz komplett verstehe ich dich nicht..

Es gibt die Klasse ReentrantReadWriteLock, die mir geeignet scheint.

Hier kannst du über readLock() bzw. writeLock() entscheiden, welche Art von Lock du benötigst. Dabei blockiert ein Writer "natürlich" alle Reader.
 

DrZoidberg

Top Contributor
Ich würde jedes mal ein neues char Array erstellen.
Java:
public void setAccectableChars(char[] accectableCharsLocal)
{
    char[] newChars = new char[accectableCharsLocal.length];
    for(int i = 0; i < accectableCharsLocal.length; i++)
    {
        newChars[i] = accectableCharsLocal[i] * 2;       
    }
    
    AccectableChars.accectableChars = newChars;
}

Wobei ich jetzt natürlich den Rest des Codes kennen müsste um beurteilen zu können ob das wirklich Thread sicher ist.
Aber der Punkt ist, dass man häufig Locks vermeiden kann, wenn man Datenstrukturen (in diesem Fall ein Array) nicht verändert, sondern neu erstellt.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
Tarrew Threading - Unregelmäßige Lock-Vergabe Allgemeine Java-Themen 0
M Lock Datei intelligent verwenden Allgemeine Java-Themen 4
S Reentrent Lock Allgemeine Java-Themen 3
T Threadsicheres wait() [lock erst mit wait() abgeben] Allgemeine Java-Themen 31
H Thread Synchronisation. mutex.lock(); und mutex.unlock(); Allgemeine Java-Themen 4
O Unterschied zwischen Semaphoren/Lock und ExecutorService Allgemeine Java-Themen 3
kodela Datenübergabe über Buttons Allgemeine Java-Themen 8
W Jar-File Start nur über Terminal Allgemeine Java-Themen 13
A ByteArray über Socket Allgemeine Java-Themen 3
berserkerdq2 Text über einen Shape anzeigen (Scenebuilder) Allgemeine Java-Themen 1
I 2D-Grafik Vektor-Grafik über die Zwischenablage nach Adobe Illustrator transferieren Allgemeine Java-Themen 8
TheSkyRider Methode über DataInputStream "auslösen" Allgemeine Java-Themen 6
I OpenPDF erzeugt riesige PDFs, wenn Grafiken über PdfGraphics2D#drawImage gezeichnet werden Allgemeine Java-Themen 1
T Etikettendrucker über TCP-IP Allgemeine Java-Themen 1
Encera Gleichzeitiges Ausführen und verbinden von 2 Java-Klassen über die Eingabeaufforderung und Eclipse Allgemeine Java-Themen 21
B HTTP Allgemeine Fragen über Suchmaschine nutzen mit Java Allgemeine Java-Themen 20
torresbig Klasse mit extends Calendar über Methoden ändern (Hirnblockade) Allgemeine Java-Themen 7
B Liste ändern während Iteration über Diese? Allgemeine Java-Themen 16
Master3000 Java Konsole über Buffered Reader Zeilenweise auslesen ? Allgemeine Java-Themen 26
J Daten über serielle Schnittstelle empfangen Allgemeine Java-Themen 4
L Aufwandsabschätzung: Android-App Aufnahmefunktion (foto) und zweiter Ebene über dem Foto (teiltransparent) Allgemeine Java-Themen 6
M Registry Autostart Eintrag mit Java erstellen (über Windows cmd) Allgemeine Java-Themen 7
OSchriever Programm über Linux-Kommandozeile ausführen Allgemeine Java-Themen 20
J Namen von Methoden über Reguläre Ausdrücke bearbeiten Allgemeine Java-Themen 6
M Schnelleres Speichern von XML-Daten über URLConnection Allgemeine Java-Themen 4
M Keine weitere Eingabe in der Main möglich. Eventueller Ansatz über while. Allgemeine Java-Themen 8
Drachenbauer Wie kann eine vorgegebene Farbe über einen String erkannt werden? Allgemeine Java-Themen 11
W Variablenübergabe über mehrere Klassen Allgemeine Java-Themen 4
N Über einen Button in JavaFX ein Event über eine Pipeline schicken(Netty) Allgemeine Java-Themen 1
M Threads über Kommandozeile Allgemeine Java-Themen 5
david19 Software AE über Domain laufen lassen Allgemeine Java-Themen 0
Q Selbständig ActionEvent auslösen zum Daten senden über serielle Schnittstelle Allgemeine Java-Themen 7
T Problem mit externen Datenbankzugriff über SSH Tunnel Allgemeine Java-Themen 4
K Auf Dateiverzeichnis extern zugreifen (evtl über XML??) Allgemeine Java-Themen 22
C VisualVM oder Jconsole über Jolokia-Proxy Allgemeine Java-Themen 0
G USB-Pins über Java ansteuern Allgemeine Java-Themen 8
Ernesto95 Best Practice Localization über ResourceBundle Allgemeine Java-Themen 6
C Classpath Neue Klasse über einen Button ausführen Allgemeine Java-Themen 3
C Auslesen auslösen über Button-Click Allgemeine Java-Themen 8
M Fragen beantworten über Textfeldeingabe Allgemeine Java-Themen 5
AssELAss Best Practice Checksumme über jede Spalte zweier Tabellen und vergleichen Allgemeine Java-Themen 3
T Strings über Bluetooth zwischen PC,µc oder Samrtphone senden und empfangen Allgemeine Java-Themen 0
F Try/catch über ganze Klasse Allgemeine Java-Themen 9
kodela Eigenartige Datumsberechnung über GregorianCalendar Allgemeine Java-Themen 15
HarleyDavidson Best Practice Integer-Zahlenfolge über mehrere Programmstarts Allgemeine Java-Themen 7
T .jar über cmd ausführen (später dann batch) Allgemeine Java-Themen 6
F In OSX: Java-Programm über URI-Scheme aufrufen mit Parameter? Allgemeine Java-Themen 0
C Input/Output Zip Files über Socket senden und empfangen Allgemeine Java-Themen 6
M WebService - Zugriff auf Webservice Methode über Browser Allgemeine Java-Themen 1
C .jar File lässt sich nur über Konsole öffnen Allgemeine Java-Themen 1
L Videodateien über Java öffnen unabhängig vom Format Allgemeine Java-Themen 4
Thallius Hash über serialisiertes Objekt? Allgemeine Java-Themen 3
T Daten über port abfangen mit proxy server Allgemeine Java-Themen 12
M Eingabe von Arrays geht über gewünschte Anzahl hinaus Allgemeine Java-Themen 2
L Prüfen, ob Programm über 32bit oder 64bit Java ausgeführt wird Allgemeine Java-Themen 4
F Content-Disposition ermitteln über URL Allgemeine Java-Themen 2
ARadauer Checksumme über BigDecimal Werte Allgemeine Java-Themen 11
A Class Datei aus Verzeichnis über URLClassLoader laden Allgemeine Java-Themen 2
G Darstellung von Ergebnissen einer Dokumentensuche über eine JTable Allgemeine Java-Themen 19
S VLC + Lied über Java starten Allgemeine Java-Themen 17
M HTML-Code von Webseite über Browser oder Console auslesen?? Allgemeine Java-Themen 5
A Sinuston ausgeben und über Mikro Amplitude messen – machbar? Allgemeine Java-Themen 6
R Java-Progamm über Icon starten unter Windows Allgemeine Java-Themen 9
C Daten über URL an PHP verschicken Allgemeine Java-Themen 4
O Fragen über Fragen - Bei Änderung XML-Datei -> Anpassung GUI Allgemeine Java-Themen 7
aze Jar ausführen über Runtime.execute funktioniert nicht Allgemeine Java-Themen 4
S NoSuchMethodError beim Ausführen einer C Methode über JNI Allgemeine Java-Themen 5
H OOP Daten über TCP Allgemeine Java-Themen 5
Pastafari Iterator über nested HashMaps Allgemeine Java-Themen 7
R ListIterator über mehrere Arrays Allgemeine Java-Themen 13
G Interface Laden der Konfiguration über Interfaces sinnvoll? Allgemeine Java-Themen 28
D Player Objekt - Frame über Server anzeigen lassen. Allgemeine Java-Themen 3
B VoIP-Gespräche über Computer führen Allgemeine Java-Themen 3
S Jar-File startet nicht über doppelklick Allgemeine Java-Themen 2
C Java Programm über SSH starten Allgemeine Java-Themen 16
K Internetverbindung über PuTTy herstellen?! Allgemeine Java-Themen 9
C Kapselung Warum graift man auf Variablen nur über Methoden und nich direkt zu? Allgemeine Java-Themen 10
G Auf Kommandozeile über Processobjekt mit Outputstream Allgemeine Java-Themen 3
S Input/Output Binärdatei über Bytestreams Allgemeine Java-Themen 4
S Kommunikation von Core und GUI über Schnittstellen Allgemeine Java-Themen 2
J Explorer über Code starten Allgemeine Java-Themen 15
kodela Problem mit Kopieren über FileChannel Allgemeine Java-Themen 4
L Java und Javascript um Distanz über Google Maps zu berchnen Allgemeine Java-Themen 10
B UNIX Shell befehl über JavaCode ausführen Allgemeine Java-Themen 19
D Java Excel API - Schreiben in Excel lässt sich nicht über Makro starten Allgemeine Java-Themen 18
M Ampelsteuerung über Timer in Java realisieren Allgemeine Java-Themen 3
L CMD über Java öffnen Allgemeine Java-Themen 8
U Mailclient über getDesktop.mail vorbereiten, Problem beim Anhang: Allgemeine Java-Themen 3
R Klasse über Button Event in anderer Klasse informieren Allgemeine Java-Themen 11
R Frequenzausgabe (2 Kanal) über Lautsprecherausgang Allgemeine Java-Themen 22
J Java-Klasse über Konsole starten Allgemeine Java-Themen 6
E FF Einstellungen über Programm ändern? Allgemeine Java-Themen 7
D JVM kann nicht über die jvm.dll gestartet werden? Allgemeine Java-Themen 1
S File im windowexploer öffnen über java Allgemeine Java-Themen 6
J Receive eines Hex-Bytes über COM-Port Allgemeine Java-Themen 4
Nicer Prozess über Prozessnamen beenden Allgemeine Java-Themen 15
reibi File über FileChannel locken Allgemeine Java-Themen 5
B Serialisierung mit Unterobjekten über Netzwerk Allgemeine Java-Themen 3
K Objekt-Austausch zwischen zwei Programmen über System-Clipboard Allgemeine Java-Themen 5
B parallele / Multithreaded Iteration über Map Allgemeine Java-Themen 12

Ähnliche Java Themen

Neue Themen


Oben