Probleme mit Deadlock-Beispiel

hdi

Top Contributor
Hey, ich suche im Moment ein gutes Bsp für ein Deadlock. Es gibt im Inet zwar genügend Code-Examples, und ich sehe auch die Deadlocks darin, finde aber irgendwie dass die Beispiele an sich schon total künstlich konstruiert sind durch scheinbar willkürliches synchen von Methoden..
Das einzige was mir im Moment von einem Anwendungsfall in der Praxis einleuchtet ist das Philosophen-Problem. Allerdings ist das ziemlich komplex und ich frage mich ob es da nicht auch ein primitiveres Bsp gibt. Nun bei meiner Suche bin ich auf das von Sun gestoßen:

(Bem.: Es geht hier um eine Begrüßung von zwei Freunden durch Verbeugen, nicht ums Bogenschiessen ;) Ist euch vllt klar aber ich hab das erstmal nich gerafft und dachte an ein RPG-Game oder so^^)

Alphonse and Gaston are friends, and great believers in courtesy. A strict rule of courtesy is that when you bow to a friend, you must remain bowed until your friend has a chance to return the bow. Unfortunately, this rule does not account for the possibility that two friends might bow to each other at the same time. This example application, Deadlock, models this possibility:

Java:
 public class Deadlock {
        static class Friend {
            private final String name;
            public Friend(String name) {
                this.name = name;
            }
            public String getName() {
                return this.name;
            }
            public synchronized void bow(Friend bower) {
                System.out.format("%s: %s has bowed to me!%n", 
                        this.name, bower.getName());
                // (1)
                bower.bowBack(this);
            }
            public synchronized void bowBack(Friend bower) {
                // (2)
                System.out.format("%s: %s has bowed back to me!%n",
                        this.name, bower.getName());
            }
        }

        public static void main(String[] args) {
            final Friend alphonse = new Friend("Alphonse");
            final Friend gaston = new Friend("Gaston");
            new Thread(new Runnable() {
                public void run() { alphonse.bow(gaston); }
            }).start();
            new Thread(new Runnable() {
                public void run() { gaston.bow(alphonse); }
            }).start();
        }
    }

So, also ein Deadlock kann auftreten - ja. Aber ich verstehe das Beispiel nicht. Warum sind die Methoden überhaupt synchronized? Ich meine ohne synch kann bei (2) geswitcht werden, was dann zu einem selstsamen Programmablauf fürhen würde.
Aber mit synch kann halt bei (1) geswitcht werden, das sind lediglich paar nanosekunden vorher und der Programmablauf würde genauso in etwas Sinnlosem enden :bahnhof:

Meine Frage also: Warum sind die Methoden synchronisiert? Ich finde das Programm hat ne Logik die nicht das erfüllt was im Text zum Beispiel gesagt wird, und irgendwie könnten da jetzt ohne sync soviele Race Conditions knallen wie sie wollen, es würde den Ablauf nicht verändern. (Bzw das synchen stellt nicht sicher dass nicht genau der selbe Mist passiert)
 
Zuletzt bearbeitet:

eRaaaa

Top Contributor
Mhm? Das Beispiel soll ja gerade zeigen, dass es so zu einem Deadlock kommen kann....gerade weil die Methoden synchronized sind ???:L

sync:
Gaston: Alphonse has bowed to me!
Alphonse: Gaston has bowed to me!
(nun wartet jeder Thread auf den anderen bei bowBack...--> Deadlock!!!)
 

hdi

Top Contributor
Ja das is schon klar, aber ich meine eig. geht es ja im Endeffekt darum zu zeigen wie und wo man wait() und notify() verwendet, um das Problem zu lösen. Genauso wie man synchronized nur verwendet wenn man 2 Threads hat die gemeinsam auf einer Resource arbeiten - dafür gibt es ja sinnvolle Anwendungsbeispiele.

kA.. also stimmst du mir zu dass hier lediglich ein Deadlock gezeigt wird, aber kein sinnvoller Code der jetzt irgendwie synchronisiert werden muss geschweige denn das tut, was Sun darüber aussagt? Finde das halt schon ein sehr madiges Beispiel dann..

Ist ja wie wenn ich jemandem den Sinn von nem Setter erklären will und sage: "Wenn die Variable private ist". Aber es geht ja darum warum die Variable überhaupt private ist. Genauso finde ich gehört zu nem Deadlock Bsp ein Anwendungsfall in dem man synchronisiert weil man sonst Race Conditions kriegt... Einfach nur paar Keywords zusammenklatschen ist ja wohl keine tolle Erklärung.
 

hdi

Top Contributor
edit: Ach alles quatsch, also ich check das Bsp echt nicht -.- Das synchen macht einfach null Sinn iwie..
 
Zuletzt bearbeitet:

MQue

Top Contributor
Also das synchronized macht ja erst den Deadlock, das Problem ist, dass beide Threads gleichzeitig starten und dann die Threads auf den anderen Thread warten, bis der was macht, ein klassischer Deadlock halt.
Probiers mal so, vielleicht hilfts fürs Verständnis(wenn du die Threads hintereinander startest, dann geht sichs aus, dass der eine schon fertig ist bevor der andere startet -> daher sind Deadlocks auch so schwierig zu finden)

Java:
public static void main(String[] args) {
            final Friend alphonse = new Friend("Alphonse");
            final Friend gaston = new Friend("Gaston");
            new Thread(new Runnable() {
                public void run() { 
                    alphonse.bow(gaston);
                    }
                }).start();
            try {
                Thread.sleep(2000);
                }
            catch(Exception e) {
                System.out.println("Ausnahme: " + e);
                }
            new Thread(new Runnable() {
                public void run() { 
                    gaston.bow(alphonse);
                    }
                }).start();
            }

Auch beim nächsten sind die Threads unabhängig (d.h. der eine Thread muss nicht auf den anderen warten) und alles funkt:

Java:
public static void main(String[] args) {
            final Friend alphonse = new Friend("Alphonse");
            final Friend gaston = new Friend("Gaston");
            new Thread(new Runnable() {
                public void run() { 
                    alphonse.bow(alphonse);
                    }
                }).start();
            new Thread(new Runnable() {
                public void run() { 
                    gaston.bow(gaston);
                    }
                }).start();
            }
 

hdi

Top Contributor
Ich glaub wir reden etwas aneinander vorbei. Mir ist schon klar was ein Deadlock ist und wie er entsteht. Es geht mir darum dass ich ein gutes Beispiel aus der Praxis suche in dem Deadlocks auftreten können. Vorbedingung ist dann also dass man etwas synchronisiert. Und dass in dem Bsp von Sun synched wird verstehe ich eben nicht - ich finde das Programm tut nicht das, was Sun sagt und muss nicht synchronisiert werden bzw. der Deadlock ist total künstlich herbeigeführt. Lass doch mal das synchronized bei den Methoden weg.. Dadurch ändert sich die Programmlogik gar nicht.
 

Firestorm87

Bekanntes Mitglied
Es geht mir darum dass ich ein gutes Beispiel aus der Praxis suche in dem Deadlocks auftreten können.
In der Praxis treten solche Deadlocks prinzipiell eher in längeren Threads auf.
Es ist ja durchaus möglich, dass solch eine Aktion nicht nur wenige millisekunden dauert, sondern vielleicht sogar mehrere Stunden.
Und um dann die gesamtgeschwindigkeit zu erhöhen Verarbeitet man mehrere Sachen parallel, die auch abhängigkeiten zueinander haben.

Und hier sollte einem ohne Probleme einleuchten, dass die wahrscheinlichkeit, dass es hier zu kollisionen kommen kann wesentlich realistischer ist, als bei 2-3 millis ;)

Zumal solche deadlocks mir bisher eher im Datenbankbereich (das managed die dann selber) oder bei den Schreibzugriffe auf Datein untergekommen sind, da zentrale Daten eben oftmals von mehreren Abläufen benötigt werden.

/EDIT: Was aber nicht heißt, dass man bei solchen Fälle wie in den Beispielen drauf verzichten kann/darf, weil das eh nicht passiert !!!!!!! Gerade an solchen Fällen kann man sehen wie "schnell" sowas gehen kann..... also lieber einmal zu vorsichtig, als einmal zu nachsichtig!
 

Janus

Bekanntes Mitglied
Das Beispiel macht genau das, was Sun sagt und auch nur genau deshalb, weil die Methoden synchronized sind.

Jemand soll sich verbeugen, bis der andere sich ebenfalls verbeugt hat. Jeder Verbeuger kann sich zu jedem Zeitpunkt nur gerade genau einmal verbeugen, oder genau einmal zurückverbeugen. Um dies zu bewerkstelligen, wird synchronized verwendet. Das Beispiel ist meiner Meinung nach exzellent.
 

FArt

Top Contributor
Du willst ein einfaches Beispiel, aber es soll nicht so künstlich sein... schwer.
Das Beispiel ist sinnvoll, das Verbeugen soll eine atomare Aktion sein, deswegen ist sie synchronisiert, und das steht in der Beschreibung. Verbeugen und Zurückverbeugen sind untersschiedliche Aktionen und somit zählt A verbeugt sich und B verbeugt sich... nicht.
Das Beispiel ist ähnlich zu den Philosophen, aber noch mal ein wenig künstlicher...
 

Marco13

Top Contributor
Man könnte jetzt versuchen, ein anderes Beispiel zu konstruieren, was mehr oder weniger eine "Umbenennung" des obigen Beispiels ist. Etwa sowas wie: Es gibt Klassen, die Nachrichten austauschen. Ein Sender schickt eine Nachricht an den Receiver. Wenn ein Receiver eine Nachricht erhält, schickt er eine Empfangsbestätigung an den Sender, der daraufhin die Nachricht aus seinem Speicher löschen kann.
Java:
class Sender
{
    private List<String> messages = new ArrayList<String>();
    
    // Muss synchronized sein, damit nicht Thread B das
    // Erstellen einer neuen Nachricht veranlasst, bevor
    // Thread A seine vorher gebaute Nachricht an den
    // Receiver geschickt hat
    public synchronized void sendMessageTo(Receiver receiver)
    {
        String message = buildMessage();
        messages.add(message);
        receiver.receiveMessage(this, messages.get(messages.size()-1));
    }

    // Muss synchronized sein, damit es nicht zwischen den 
    // obigen Zeilen mit 'messages.add' und 'reveicer.receiveMessage'
    // aufgerufen werden kann
    public synchronized void discardMessage(String message)
    {
        messages.remove(message);
    }
}


class Receiver
{
    private String lastMessage;

    // Muss synchronized sein, damit nicht zwischen den
    // beiden Zeilen ein anderer Thread die Methode aufruft
    public synchronized void receiveMessage(Sender sender, String message)
    {
        lastMessage = message;
        sender.discardMessage(lastMessage);
    }

}

Da müßte es auch einen Deadlock geben können... ? (Müßte man aber nochmal genauer verifizieren, so früh am Morgen und mit so einem niedrigen Koffeinspiegel will ich da mal keine Garantien geben ;) )

Ist halt AUCH konstruiert, aber zumindest habe ich versucht, die synchronizations zu rechtfertigen... Vielleicht wird wenigestens die Grundidee deutlich....
 

JanHH

Top Contributor
Naja, Abstürze und Fehler treten ja nunmal wegen Programmierfehlern auf, die KEINEN Sinn machen. Sicher sind die synchronizeds bei solchen Beispielen falsch und unsinnig. Aber da falsches und unsinniges Programmieren nunmal die Ursache von Fehlern ist, sind auch solche Beispiele legitim und sinnvoll.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
C Probleme beim Erstellen eines runnable-jar files Allgemeine Java-Themen 1
S Umstellung von File auf Path - Probleme mit Stream Allgemeine Java-Themen 5
C Probleme mit javax.mail.Session Allgemeine Java-Themen 8
M tomcat probleme Allgemeine Java-Themen 1
N Division macht Probleme Allgemeine Java-Themen 14
B Java Reflection Probleme beim wehcselseitigen Referenzieren zweier Klassen/Objekte Allgemeine Java-Themen 14
MarvinsDepression Probleme mit relativem Dateipfad Allgemeine Java-Themen 1
G Geotools Probleme nach PC-Wechsel Allgemeine Java-Themen 6
nibe1501 GUI Probleme Allgemeine Java-Themen 16
C Probleme mit dem WindowBuilder Allgemeine Java-Themen 3
P Selenium . Probleme ein Iron Icon Element anzusprechen Allgemeine Java-Themen 2
B Compiler-Fehler Probleme beim Kompilieren mit Jsoup Allgemeine Java-Themen 8
K VisualVM Profiling Remote Probleme Allgemeine Java-Themen 1
O Leerzeichen und Umlaute im Pfad einer Java Applikation machen Probleme Allgemeine Java-Themen 13
M Probleme bei Eclipse wenn ich entpacke Allgemeine Java-Themen 15
D Regex Probleme Allgemeine Java-Themen 2
M Probleme jar datei. Allgemeine Java-Themen 2
L Vererbung Verständnis Probleme Vererbung Allgemeine Java-Themen 2
Dann07 Probleme mit OpenAL Allgemeine Java-Themen 0
V Threads Probleme beim Aufrufen von Methoden einer anderen Klasse (Threads) Allgemeine Java-Themen 14
V Compiler-Fehler Online Compiler Probleme Allgemeine Java-Themen 4
M Probleme mit Negamax-Algorithmus Allgemeine Java-Themen 29
M Probleme mit BigDecimal Allgemeine Java-Themen 1
T Probleme mit NumberFormat Allgemeine Java-Themen 5
J Probleme exe-Start mit Task Scheduler Allgemeine Java-Themen 1
B Input/Output Probleme beim Ausführen von Shell-Befehlen mit Java Allgemeine Java-Themen 28
J Probleme beim einbinden von Zip4j library Allgemeine Java-Themen 6
F Variablen Palindromzahl (Probleme mit Methode) Allgemeine Java-Themen 9
K Data Konverter - Probleme mit Byte[] Kodierung Allgemeine Java-Themen 3
T Probleme mit dem Pfad zum Propertie file Allgemeine Java-Themen 7
H Swing HashMap zu Tabelle macht mir Probleme Allgemeine Java-Themen 4
Neoline Interpreter-Fehler Probleme mit Arrays.toString Allgemeine Java-Themen 7
F SQLite mit Java / Probleme beim INSERT Befehl Allgemeine Java-Themen 4
J Erste Schritte Probleme mit der Hauptklasse Allgemeine Java-Themen 14
J Tetris Probleme bei Klassen Allgemeine Java-Themen 14
J MinMax VierGewinnt Probleme Allgemeine Java-Themen 22
J Probleme mit CodeCoverage und Lombok Equals Allgemeine Java-Themen 1
S Eclipse Probleme beim Implementieren / Ausführen von jUnit 5-Test Suites Allgemeine Java-Themen 14
R Snake Probleme Allgemeine Java-Themen 2
A Probleme beim Verstehen einer Aufgabenstellung Allgemeine Java-Themen 11
RalleYTN 3D Objekt Translation basierend auf Rotation (Probleme mit Z Rotation) Allgemeine Java-Themen 0
Bluedaishi Druck Probleme mit PDF dateien Allgemeine Java-Themen 4
G Ant Probleme bei einer Installation die Apache ant+ivy verwendet Allgemeine Java-Themen 14
E TableView Probleme Allgemeine Java-Themen 7
perlenfischer1984 Probleme beim Mocken Allgemeine Java-Themen 6
S Kaffemaschine Programmierung Probleme Allgemeine Java-Themen 2
K Threads Runtime und Process Probleme Allgemeine Java-Themen 3
S Probleme mit unterschiedlichen Java-Versionen (Mac OS X 10.11) Allgemeine Java-Themen 0
S Event Handling keyPressed()-Probleme Allgemeine Java-Themen 2
VfL_Freak Große und seltsame Probleme nach Java-Update auf V1.8.0_91 Allgemeine Java-Themen 3
P Probleme mit Grafik (Java) Allgemeine Java-Themen 6
R probleme beim starten von jar unter linux Allgemeine Java-Themen 2
H Probleme mit DAY_OF_WEEK Allgemeine Java-Themen 4
Arif Probleme mit NullPointerException Allgemeine Java-Themen 2
E Probleme mit nextInt() und Exception Allgemeine Java-Themen 35
Streeber Probleme mit AWT-EventQueue: ArrayList Elemente hinzufügen Allgemeine Java-Themen 1
D Performance-Probleme mit Joda-Time Allgemeine Java-Themen 3
M Probleme beim rechnen, bei Zahlen mit führenden Nullen. Allgemeine Java-Themen 7
RalleYTN Probleme mit Encrypting Allgemeine Java-Themen 10
M Probleme mit Schriftarten PDFBox Allgemeine Java-Themen 3
J Probleme mit der Java-Runtime Allgemeine Java-Themen 10
G Probleme mit BufferedWriter und URL Allgemeine Java-Themen 4
S Probleme mit meinem MacBook Pro DRINGEND HILFE erbeten! Allgemeine Java-Themen 17
Androbin Interpreter-Fehler Probleme mit Rekursion - StackOverflowError Allgemeine Java-Themen 8
E JCuda-0.6.5 Probleme beim ausführen der Datei Allgemeine Java-Themen 0
M Runtime.exec() verursacht auf manchen Systemen Probleme - Ursache unklar Allgemeine Java-Themen 2
W JNDI - LDAP - Probleme beim editieren von Usern Allgemeine Java-Themen 0
R DBUnit Performance Probleme Allgemeine Java-Themen 0
S Probleme mit Collection Allgemeine Java-Themen 7
L Probleme mit Jar Allgemeine Java-Themen 6
N Zahlensysteme umrechnen; Probleme beim Umwandeln Allgemeine Java-Themen 4
K OOP OOP Gui Spiel + Vererbungen Probleme durch Nichtwissen!! Allgemeine Java-Themen 1
F Java Native/Shared Library (.so) laden macht Probleme Allgemeine Java-Themen 3
J Synchronized Probleme Allgemeine Java-Themen 7
J Java Progressbar & Download Probleme Allgemeine Java-Themen 10
S Probleme mit dem filechooser Allgemeine Java-Themen 1
J Comperator Probleme Allgemeine Java-Themen 4
A Probleme beim auslesen von Quelltext (HTML) Allgemeine Java-Themen 5
S Probleme mit Webappplikation Allgemeine Java-Themen 5
L Plötzlich Probleme mit der JVM :( Allgemeine Java-Themen 6
S starke performance probleme des forums Allgemeine Java-Themen 10
K Probleme bei Berechnung der Komplexität Allgemeine Java-Themen 7
R JRE Ablaufdatum seit 7u10 - Probleme bei selbst ausgelieferter JRE bekannt? Allgemeine Java-Themen 3
H Reg Exp Probleme Allgemeine Java-Themen 5
M Classpath Probleme bei JAR Generierung Allgemeine Java-Themen 2
S Probleme mit JAVA-Installation Allgemeine Java-Themen 3
D Probleme bei for-Schleife Allgemeine Java-Themen 4
R Probleme mit Javadoc Allgemeine Java-Themen 2
G Gson Probleme Allgemeine Java-Themen 2
P KI für TicTacToe programmieren > Probleme Allgemeine Java-Themen 2
M Google App Engine macht Probleme Allgemeine Java-Themen 4
H Probleme mit finally-Block und close() Allgemeine Java-Themen 4
F 2d array probleme Allgemeine Java-Themen 2
M 3D-Grafik Probleme beim drehen von Objekten Allgemeine Java-Themen 9
T Interface Probleme Allgemeine Java-Themen 8
C Eclipse Probleme bei selbst erstelltem Algorithmus Allgemeine Java-Themen 2
M Probleme mit String in Label übergeben. Allgemeine Java-Themen 6
H MediaManager Fragen/Probleme Allgemeine Java-Themen 6
U Probleme mit Kopiervorgang Allgemeine Java-Themen 3
S Probleme beim Auslesen einer Liste Allgemeine Java-Themen 8

Ähnliche Java Themen

Neue Themen


Oben