Philosophenproblem, Threads und Deadlocks

Status
Nicht offen für weitere Antworten.
H

Hosiki

Gast
hi,

ich hab hier diese Aufgabe
Modellieren Sie das Problem der speisenden Philosophen so, dass kein Deadlock
eintreten kann. Dass Problem besteht kurz darin, dass n Philosophen an einem kreisrunden
Tisch sitzen und Spaghetti essen wollen. Dass schafft ein Philosoph nur, wenn er über 2
Gabeln verfügt. Vor jedem Philosophen steht ein Teller mit Spaghetti, zwischen 2 Tellern
liegt jeweils eine Gabel. Es ist nicht schlimm, dass nicht alle Philosophen gleichzeitig essen
können, da Philosophen gerne denken und einfach warten bis die Nachbarn ihre Gabel nach
dem Essen wieder an die alte Stelle zurücklegen. Es gibt aber ein Problem, wenn alle
Philosophen gleichzeitig die rechts von ihnen liegende Gabel (oder alle die linke Gabel)
ergreifen. Dann entsteht ein Deadlock, weil kein Philosoph essen kann, da er nicht an die
zweite Gabel herankommt.

Mein Programm läuft soweit, nur nach ein paar Sekunden erreich ich den Deadlock - nun hab ich schon was gegrübel wie ich den den Deadlock vermeiden kann, bin aber auf keine Lösung gestoßen die nicht letzendlich vom Zufall abhängt.

Jemand ein Idee wie ich das geregelt krieg ohne das es Zufallsgesteurt ist?
 

Marco13

Top Contributor
Ganz pragmatisch zusammengefasst (man findet da auch ausführliche Webseiten drüber): Ein Philosoph darf nur dann beide Gabeln nehmen, wenn er sich beide nehmen kann, ohne dass ihm jemand dazwischenkommt.
 
G

Gast

Gast
Ohne code, beschreibung was man macht etc. mal wieder schwer zu beantworten. Im ersten Ansatz schmeiß ich dir mal das Schlüsselwort synchronized an den Kopf. Damit lässt sich das Problem vermeiden.
 
G

Guest

Gast
Gast hat gesagt.:
Ohne code, beschreibung was man macht etc. mal wieder schwer zu beantworten. Im ersten Ansatz schmeiß ich dir mal das Schlüsselwort synchronized an den Kopf. Damit lässt sich das Problem vermeiden.

Nein, leider nicht.

wenn jeder philosoph eine gabel im zugriff hat und darauf wartet das der andere die fehlende zweite gabel frei gibt warten alle auf den anderen ohne ende ;-)

eine gabel ist eine selbst geschriebene semaphore:
Code:
public class MySemaphore 
{
	private final int max_allowed;
	private int currentInUse=0;
	
	public MySemaphore(int allowed)
	{
		max_allowed = allowed;
	}
	
	public synchronized void acquire() throws InterruptedException
	{
		while (currentInUse == max_allowed)
			wait();
		currentInUse++;
		return;
	}
	
	public synchronized void release()
	{
		if (currentInUse - 1 > 0)
			currentInUse--;
		
		notifyAll();
	}
	
	

}

public class Fork extends MySemaphore
{
	private String name;

	public Fork(String name) 
	{
		super(1);
		this.name = name;
	}

	public String getName() {return name;}

}

es gibt N philosophen thread und n sempahoren (gabeln), jeder philosoph arbeitet so:

Code:
package auf2_Philosophen;


public class Philosoph implements Runnable
{
	String		 name;
	Fork		 forkLeft;
	Fork 		 forkRight;
	
	public Philosoph(String name)
	{
		this.name = name;
	}
	
	public void setForkLeft (Fork l) {forkLeft  = l;}
	public void setForkRight(Fork r) {forkRight = r;}

	public void run() 
	{
		while(true)
		{
			thinkAboutIt();
			try {spachteln();} catch (InterruptedException e) { e.printStackTrace();}
		}
	}
	
	private void thinkAboutIt()
	{
		System.out.println(name + " denkt ....");
	}
	
	private void spachteln() throws InterruptedException
	{ 
		System.out.println(name + " versucht rechte Gabel zu nehmen");
		forkRight.acquire();
		System.out.println(name + " hat rechte Gabel");
		
		System.out.println(name + " versucht linke Gabel zu nehmen");
		forkLeft.acquire();
		System.out.println(name + " hat linke Gabel");
		System.out.println(name + " hat 2 Gabeln und isst");
		forkRight.release(); forkLeft.release();
		System.out.println(name + " hat seine Gabeln zurück gelegt");
	}
	
	public void print()
	{
		System.out.println(name + " L:" + forkLeft.getName() + " R:" + forkRight.getName());
	}

}
 
S

Spacerat

Gast
Hallo

1. Das riecht nach Hausaufgaben...

2. Mensch... das sind Philosophen (verdammich :)). Und Philosophen denken... Warum also nicht auch daran, sich beide Gabeln "gleichzeitig" zu schnappen?

Aber mal Scherz beiseite. Es geht im Prinzip nur um die Antwort, wie man Deadlocks verhindert. Und das geht nunmal (wie vom 1. Gast schon ganz pragmatisch erwähnt) mit "synchronized". "Gleichzeitigkeit" ist bei Mensch und Maschine nie wirklich gegeben, sondern lediglich in individuellen Grenzen toleriert. Deine Philosophen-Threads kannst du nur nacheinander starten. Deswegen hat der erste Philosoph bereits zwei Gabeln in der Hand, bevor der letzte sich auch nur eine greifen konnte (sprich: sein Thread gestartet wurde.).

Entscheidend für dein Problem, das hier trotzdem ein Deadlock entsteht, ist die Tatsache, das jede einzelne Gabel von "max_allowed" Philosopen benutzt werden kann (synchronized this!) und eigentlich nur eine davon existiert. Die Klasse Fork müsste eigentlich ungefähr so aussehen:
Code:
public class Fork
{
  private boolean inuse = false;

  public synchronized boolean aquire()
  {
    if(inuse) return false;
    inuse = true;
    return true;
  }

  public synchronized void release()
  {
    inuse = false;
  }
}
Und dann darf pro Philosoph natürlich nur ein Objekt instanziert werden. Ein Philosoph sieht dann ungefär so aus:
Code:
public class Philosoph
extends Thread
{
  private final Fork left;
  private final Fork right;

  public Philosoph(int count)
  {
    if(count <= 0) throw new RuntimeException("illegal value");
    left = new Fork();
    Philosoph tmp = null;
    for(int n = 0; n < count - 1; n++) tmp = new Philosoph(tmp);
    right = tmp.left;
    start();
  }

  private Philosoph(Philosoph left)
  {
    right = (left != null)? left.left : new Fork();
    this.left = new Fork();
    start();
  }

  public void run()
  {
    try {
      boolean aquired = false;
      while(!aquired) aquired = left.aquire();
      aquired = false;
      while(!aquired) aquired = right.aquire();
      Thread.sleep(10000);
      left.release();
      right.release();
    } catch(InterruptedException e) {
      // do nothing
    }
  }
}

So. Ich hab' das mal so hier im Editorfenster hardcoded. Das bedeutet, das ich das 1. nicht getestet habe und 2. das sich Syntaxfehler eingeschlichen haben könnten. Aber von der Logik her sollte das funzen... ohne Deadlocks!

mfg Spacerat
 
S

Spacerat

Gast
Hier ist 'ne prinzipiell identische Form meiner Lösung. Die Änderungen belaufen sich auf folgende Dinge.
1. Klasse Philosoph zwecks Ausgabe in die Konsole leicht verändert. Ablauf bleibt der selbe.
2. Unnötiges "synchonized" aus Fork.release() entfernt.
3. Klasse Fork als statische Memberklasse eingefügt. Erleichtert lediglich "copy & paste".
4. "main()"-Methode zum testen hinzugefügt.
5. Einen geringfügigen Fehler in der Verteilung der Gabeln beseitigt.
Code:
public final class Philosoph
extends Thread
{ 
  private final Fork left;
  private final Fork right;
  private String name;

  public Philosoph(int count)
  {
    if(count <= 0) throw new RuntimeException("illegal value");
    left = new Fork();
    Philosoph tmp = this;
    for(int n = 1; n < count; n++) {
    	tmp = new Philosoph(tmp);
    	tmp.name = "Philosoph " + n;
    }
    name = "Philosoph " + count;
    right = tmp.left;
    start();
  }

  private Philosoph(Philosoph left)
  {
    right = (left != null)? left.left : new Fork();
    this.left = new Fork();
    start();
  } 

  public void run()
  {
    try {
    try {
      boolean eat = false, aql = false, aqr = false;
      while(!eat) {
        System.out.println(name + " thinks...");
        Thread.sleep(1000);
        while(!aql) aql = left.aquire();
        System.out.println(name + " got left Fork");
        System.out.println(name + " thinks about philosopy...");
        Thread.sleep(1000); // forced Deadlock before
        while(!aqr) {
          aqr = right.aquire();
          if(!aqr) {
            left.release();
            aql = false;
            System.out.println(name + " released left Fork");
          }
        }
        System.out.println(name + " got right Fork");
        eat = aql && aqr;
      }
      System.out.println(name + " eats");
      Thread.sleep(10000);
      left.release();
      System.out.println(name + " released left Fork");
      right.release();
      System.out.println(name + " released right Fork");
    } catch(InterruptedException e) {
      // do nothing
    }
  }

  private static class Fork
  {
    private boolean inuse = false;

    /**
     * Gabel nehmen
     * ... wird "synchronized" entfernt kann es zu DeadLocks kommen.
     * Es verhindert den Versuch zweier Philosophen, gleichzeitig
     * die Gabel zu nehmen.
     * @return boolean Erfolg/Misserfolg
     */
    public synchronized boolean aquire()
    {
      if(inuse) return false;
      inuse = true;
      return true;
    } 

    /**
     * Gabel weglegen
     * ... "synchronized" ist hier nicht erforderlich.
     * Die Gabel kann ja nur von einem Philosophen genommen werden.
     * Deswegen kann sie auch nur ven einem gleichzeitig weggelegt
     * werden.
     */
    public void release()
    {
      inuse = false;
    }
  }

  public static void main(String args[])
  {
    new Philosoph(10);
  }
}

Die Idee aus dem Link von Landei, das die Philosophen die erste Gabel weglegen sollen wenn sie die Zweite nicht bekommen können sowie die Tatsache, das sie zunächst Nachdenken sollen habe ich mir gespart. Das lässt sich bei Interesse aber noch nachliefern.

mfg Spacerat
 
H

Hosiki

Gast
danke für die vielen ansätze, ansich plausibel, wie einer der vorsprecher bemerkt hat, sind das hausaufgaben. Als nebenbedinung ist das hier allerdigns noch mit im spiel:

Die Philosophen sollen durch Threads dargestellt werden. Sie versuchen 2 Gabeln
zu erwischen; dann essen sie und anschließend legen sie beide Gabel zurück. Die Gabeln
sollen durch Semaphor-Objekte aus dem Paket java.util.concurrent repräsentiert
werden. Das Problem ist nur dann lösbar, wenn sich nicht alle Philosophen identisch
verhalten. Die Vermeidung des Deadlock soll natürlich nicht auf bloßem Zufall beruhen!

die semaphore aus dem concurrent package arbeitet ja praktsich wie meine, sieht versucht den lock zu bekommen, ansonsten gehts sie auf wait() und wartet auf ein notify(all)

krieg ich das deadlock save gelöst mit der sempahoren semantik ? ich hab daran mittlerweile kapituliert weil ich im grunde immer wieder vom zufall abhänge, was nicht sein soll (laut aufgabenstellung)
 
S

Spacerat

Gast
Hosiki hat gesagt.:
...wie einer der vorsprecher bemerkt hat, sind das hausaufgaben.
Hab' ich mir gedacht, auch wenn's nicht in dieses Schema passt. Aber da ja ein eigenes Konzept vorhanden ist, nehme ich mal an, das dieses Thema nicht gegen die Boardregeln verstösst. BTT.

Zu deinem Problem... Ich hab' mich über diese Semaphoren-Geschichte mal kurz informiert und muss sagen, dass das für die Aufgabenstellung ziemlich überzogen ist da man für eine Gabel ja nur eine "permission" (in Benutzung oder nicht) braucht, mit Semaphoren allerdings weit mehr möglich sind, weil dort ein int dafür "verschwendet" wird. Faktisch stellt sich mir zudem auch keine Möglichkeit dar, wie ein Philosoph mit bekommen sollte ob der Griff nach der Gabel erfolgreich war oder nicht. Dazu fehlt bei "aquire()" ein Rückgabewert (boolean). Erschwerend kommt dann noch hinzu, das ein Philosoph bei einem Fehlversuch eine zweite Gabel zu bekommen, keine Möglichkeit hat die erste wieder fallen zu lassen und alles von vorne zu versuchen (Ist für die Verhinderung des Deadlocks ebenfalls erforderlich. Und ob nun Semaphore-Objekt oder nicht... Das ist wahrscheinlich der Löwenanteil der Lösung).

Hosiki hat gesagt.:
Die Vermeidung des Deadlock soll natürlich nicht auf bloßem Zufall beruhen!
Was genau ist ein DeadLock? Letztenendes doch ein Ereignis, welches auf blossem "Zufall" beruht. Es ist ja gerade bei der Geschichte mit den Philosophen der Zufall, der alle zur gleichen Zeit dazu bewegt, sich die jeweils linke Gabel zu nehmen. Wenn das passiert hat jeder eine Gabel in der Hand und für keinen ist eine zweite da. Das bedeutet, dass alle Threads danach in der Warteschleife hängen um eine zweite zu bekommen. Was aber nicht geht, weil keiner Anfangen kann zu essen. Und da fällts auch mir wie Schuppen aus den Haaren... ein simples "synchronized" reicht da ohnehin nicht. Ich schreibe da mal eine Zeile in meinen Code, die den Deadlock forcieren dürfte.

mfg Spacerat
 

hdi

Top Contributor
Hö, was redet ihr denn da :shock:

Die Vermeidung von Deadlocks mit synchronized? synchronized ist der Grund für Deadlocks.
Ohne Synchronisation kein (aktiver) Monitor, ohne Monitor keine Semaphore, ohne Sempahore kann es nicht
zu der Situation kommen, dass 2 Threads gegenseitig auf Resourcen warten.

Und die Lösug dafür ist wait/notify.

Ihr sprecht hier von was anderem: Synchronized ist die Lösung für Race Conditions.
 
S

Spacerat

Gast
@hdi: Ok... das hat bei genauer Betrachtung durchaus Sinn... wenn man sich im Klaren darüber ist, was Deadlocks sind und wie sie zustande kommen. Obwohl... "synchronized" wäre dann nur meistens und nicht immer der Grund dafür. Sind wir uns einig, das es in meinem Code oben auch ohne "synchronized" zu einem Deadlock kommt? Wenn nicht, dann folgendes: Jeder Philosoph kann sich zunächst die linke Gabel greifen. Die Tatsachen, das sich zwei Philosophen eine Gabel teilen müssen, und das der Vorgang sich die rechte Gabel zu greifen erst beginnt, wenn alle die Linke bereits in der Hand haben, macht "synchronized" hier recht überflüssig. Theoretisch hätte ich also keinen Monitor. An diesem Punkt möchte ich nochmals klarstellen, das ich wirklich wenig Ahnung von "Semaphoren" habe. Ich sehe nur, das die Gabeln alle "inuse" sind und genau dort habe ich meinen Monitor. Kann es sein, das genau dieser boolsche Wert eine Semaphore ist? Fakt ist, das nun alle Philosophen darauf warten, das ihr jeweils rechter Nachbar seine Linke Gabel wieder freigibt. Und genau das ist des Rätsels Lösung. Die Philosopen müssen (auch wenn weiterhin absolut kein interesse daran besteht :) ) die Linke Gabel wieder freigeben, wenn der Versuch, sich die Rechte zu greifen fehlschlug. Ich ändere das mal... ("synchronized" bleibt aber drin...)

@Hosiki: Nun sind es wohl nicht einfach nur mehr Hausaufgaben... "hdi" hat mich da auf etwas gebracht, was mich dazu anspornt, mir diese Geschichte mit den Semaphoren mal genauer anzuschauen.

mfg Spacerat
 

hdi

Top Contributor
@ Spacerat:

Ohne Synchronisation gibt es nie Deadlocks. Nur, weil du das Schlüsselwort synchronized nicht benutzt, heisst das nicht, dass du nicht synchronisierst! Ob jetzt "synchronized" oder selber einen Monitor zusammenbauen mit booleschen Variablen wie "eat" usw kommt auf's selbe raus, zumindest von der Idee her. Wobei eine Boolesche Variable keine Sempahore sind, Semaphore arbeiten atomar was eine normale Boolesche nicht tut. Da steckt noch bisschen mehr dahinter:
http://www.artima.com/insidejvm/ed2/threadsynch.html

ich würde also lieber mit synchronized arbeiten und nicht mit irgendwelchen eigenen booleans und while-Schleifen.
Wie gesagt, die Lösung für Deadlocks bei synchronized sind die Methoden wait() und notify().
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
rode45e Java Threads Allgemeine Java-Themen 4
M Threads Allgemeine Java-Themen 1
L Threads Threads in Chatroom Allgemeine Java-Themen 30
berserkerdq2 run-methode eines Threads so programmieren, dass 30x die Sekunde etwas ausgeführt wird. Allgemeine Java-Themen 44
berserkerdq2 Threads, wie genau läuft das in Java ab? (Ich kann Threads erstellen und nutzen, nur das Verständnis) Allgemeine Java-Themen 6
CptK Backpropagation parallelisieren: Kommunikation zwischen den Threads Allgemeine Java-Themen 7
J Eine Frage zu den Threads und Task Allgemeine Java-Themen 1
W Wieviele Threads sind sinnvoll? Allgemeine Java-Themen 8
W Alternative für Threads Allgemeine Java-Themen 6
V Threads Probleme beim Aufrufen von Methoden einer anderen Klasse (Threads) Allgemeine Java-Themen 14
T Multithreading: Wie viele Threads sollte ich erstellen? Allgemeine Java-Themen 12
G Threads vom Mainprogramm steuern Allgemeine Java-Themen 8
S BlockingQueue mit dynamischer Anpassung der Anzahl von Producer und Consumer Threads Allgemeine Java-Themen 1
x46 Threads Threads anhalten Allgemeine Java-Themen 1
J Threads verbessern die Performance NICHT ? Allgemeine Java-Themen 8
W Threads Problem Allgemeine Java-Themen 15
T Threads Tic Tac Toe mit Threads Allgemeine Java-Themen 1
M Threads über Kommandozeile Allgemeine Java-Themen 5
mrbig2017 Threads Chat Programm mit Threads? Allgemeine Java-Themen 2
J Threads - java.lang.IllegalThreadStateException Allgemeine Java-Themen 6
J Internet Broswer in Threads öffnen Allgemeine Java-Themen 1
B Threads Multithreading Threads sollen warten Allgemeine Java-Themen 12
N 1000 MQTT Messages die Sekunde - 1000 Threads erstellen ? Allgemeine Java-Themen 10
D Threads Parallel laufende Threads Allgemeine Java-Themen 4
J Unvorhersehbares Verhalten - benutze ich die falsche Bedingungsprüfung oder brauche ich Threads? Allgemeine Java-Themen 12
D Eine Forschleife mit Threads abarbeiten um es zu schneller zu machen. Ist das möglich? Allgemeine Java-Themen 20
S Wie kann ich eine kleine Stelle in meinem Code mit multiplen Threads abarbeiten..? Allgemeine Java-Themen 20
P Threads Parallelisierte DB-Abfragen mit variabler Anzahl an Threads Allgemeine Java-Themen 4
J Threads Threads Allgemeine Java-Themen 9
Viktim Threads Liste In unterschiedlichen Threads bearbeiten Allgemeine Java-Themen 23
E Threads Ausführung in Threads ist langsamer als ohne Threads Allgemeine Java-Themen 13
A Anzahl an Threads Systemweit Allgemeine Java-Themen 2
Tausendsassa Input/Output Problem mit der gleichzeitigen Ausgabe zweier Threads Allgemeine Java-Themen 8
S Alle Methodenaufrufe eines Threads notieren..? Allgemeine Java-Themen 7
M Threads JPanel eingeforen mit Threads Allgemeine Java-Themen 2
F Threads Allgemeine Java-Themen 6
F Threads Allgemeine Java-Themen 2
M Sinn von Threads? Allgemeine Java-Themen 1
J Wie erschaffe ich einen sicheren Datenaustausch zwischen Thread und Nicht-Threads Allgemeine Java-Themen 8
L Abfragen ob Threads fertig Allgemeine Java-Themen 3
P Threads Java Zugreifen Allgemeine Java-Themen 6
K Problem: Java-Klasse mit mehreren Threads als eigenen Prozess starten Allgemeine Java-Themen 3
K KeyEvent in Threads Allgemeine Java-Themen 11
V Threads Weshalb funktionieren meine Threads nicht? Allgemeine Java-Themen 2
Thallius Speicherverhalten von Properties und mehreren Threads Allgemeine Java-Themen 5
L Threads beenden Allgemeine Java-Themen 4
P Threads Threads nicht gleichzeitig starten Allgemeine Java-Themen 3
S Threads Threads werden nicht beendet Allgemeine Java-Themen 2
S Start des zweiten Threads erst nach Beenden des ersten Threads Allgemeine Java-Themen 13
N Threads statische Methoden in Threads Allgemeine Java-Themen 5
P 4 Threads in einer Methode Allgemeine Java-Themen 2
M Eclipse Mehrere Threads, mehrere Konsolen Allgemeine Java-Themen 4
OnDemand Threads und synchronized Allgemeine Java-Themen 9
R LinkedList und Threads: Strukturprobleme bez. löschen von Elementen Allgemeine Java-Themen 3
R LinkedList und Threads - welche Methode ist besser? Allgemeine Java-Themen 2
OnDemand Threads und synvhronized Allgemeine Java-Themen 2
S Problem mit Threads Allgemeine Java-Themen 1
W Threads Threads warten lassen Allgemeine Java-Themen 5
H Optimierung durch Threads Allgemeine Java-Themen 31
B Threads halten sich irgendwie auf... Allgemeine Java-Themen 6
M Threads Allgemeine Java-Themen 8
K JNI: Methoden aus unterschiedlichen Threads aufrufen Allgemeine Java-Themen 3
A Applet Alle Threads beim schließen des Applets beenden Allgemeine Java-Themen 8
A Problem mit der Synchronisierung von Threads Allgemeine Java-Themen 15
R SecurityManager für einzelne Klassen/Threads? Allgemeine Java-Themen 38
O Threads und If Befehle Allgemeine Java-Themen 7
P Threads abwechseln lassen mit wait() und notify() Allgemeine Java-Themen 2
H Sehr viele Threads effizient Verwalten Allgemeine Java-Themen 13
C Threads und Exceptions Allgemeine Java-Themen 7
H java.lang.OutOfMemoryError bei der wiederholten Erzeugng von Threads Allgemeine Java-Themen 8
S Threads Abarbeitungsstatus von Threads in Datei schreiben Allgemeine Java-Themen 2
M Zugriff zweier Threads auf diesselbe Methode Allgemeine Java-Themen 16
E Threads Sudoku Threads Allgemeine Java-Themen 8
M Java Threads - Wait Notify - Verständnisproblem Allgemeine Java-Themen 5
Gossi Threads mit unterschiedlichen Aufgaben in einer Klasse? Allgemeine Java-Themen 9
G Threads Ablauf von Threads im Spezialfall Allgemeine Java-Themen 4
V Threads bei quadcore Allgemeine Java-Themen 10
V 1000 Threads oder Iterativ? Allgemeine Java-Themen 11
4 Simple(?) Frage zu Threads Allgemeine Java-Themen 14
B Threads Game of Life - Threads Allgemeine Java-Themen 49
R Threads Exceptions von Threads abfangen im ThreadPool Allgemeine Java-Themen 5
S Threads Ende sämtlicher Threads abwarten Allgemeine Java-Themen 6
S Frage zu Threads (Sichtbarkeit und Verhalten) Allgemeine Java-Themen 11
M Java-Threads und Datentypen-Zugriffe Allgemeine Java-Themen 7
P Threads- Programming Allgemeine Java-Themen 2
G Threads Klasse Sound und Threads bleiben hängen Allgemeine Java-Themen 4
C Threads Zwei Threads greifen auf LinkedList zu. Allgemeine Java-Themen 12
M OutOfMemoryError in nebenläufigen Threads Allgemeine Java-Themen 6
M Threads dauerhafte bewegung mit threads Allgemeine Java-Themen 11
frankred Threads Auf eine Gruppe von Threads warten Allgemeine Java-Themen 11
J Eure Meinung: Threads verwenden, oder nicht? Allgemeine Java-Themen 6
K Warum wartet diese Funktion auf beenden des Threads? Allgemeine Java-Themen 3
F Mehrere Threads - ein Stack Allgemeine Java-Themen 6
O Wie kann ich das Ende eines Threads melden? Allgemeine Java-Themen 7
J Writer und Threads Allgemeine Java-Themen 2
G mehrere Threads starten/stoppen Allgemeine Java-Themen 4
E Verständnisfrage bezüglich Threads Allgemeine Java-Themen 4
K Zeitkritische Threads Allgemeine Java-Themen 14
K Threads - Swing - Synchronisation nötig? Allgemeine Java-Themen 8
S [THREADS] Thread sinnvoll beenden Allgemeine Java-Themen 2

Ähnliche Java Themen

Neue Themen


Oben