Threads - summieren

minzee

Bekanntes Mitglied
Hi :)

Ich hab leider scheinbar echt Probleme mit Threads. Scheinbar schaff ich noch nicht mal die einfachsten Sachen :(

Ich wollte mal ein wenig mit http://www.umiacs.umd.edu/users/vishkin/PUBLICATIONS/classnotes.pdf herumexperimentieren, aber scheiter leider gleich am Anfang beim ersten Algorithmus 1 (summation) auf Seite 10. Irgendwie ist das ziemlich frustrierend. Dabei dachte ich echt, ich hätte eine Möglichkeit gefunden:

Java:
class B 
{
   private int v;                 // Wert
   private boolean valid = false; // ob B schon einen Wert hat

   public void set(int v)
   {
      this.v = v;
      valid = true;
      
      notifyAll();
   }
   public int get(int h, int i)
   {
      while(!valid)
      {
         try
         {
            System.out.println("waiting h: " + h + ", i: " + i);
            wait();
         }
         catch(InterruptedException e)
         {
         }
      }
      return v;
   }
}
class T extends Thread
{
   private int i;
   private int[] a;
   private B[][] b;
   
   /**
    * @param int i Thread-ID >= 0
    * @param int[] a Daten
    * @param B[][] b Summen
    */
   public T(int i, int[] a, B[][] b)
   {
      this.i = i;
      this.a = a;
      this.b = b;
      
      start();
   }
   public void run()
   {
      System.out.println("i: " + i);
      
      int n = a.length;                            // Anzahl der Werte in a = 8
      int logN = (int)(Math.log(n) / Math.log(2)); // log2(n), bei n = 8 => 3
      
      b[0][i].set(a[i]);                           // unterste Reihe in der Baumstruktur (h = 0)
      for(int h = 1; h <= logN; ++h)               // Höhe. Bei n = 8 läuft jeder Thread von 0 bis 3.
      {
         if(i < n / Math.pow(2, h))                // Allerdings führt nich jeder Thread in jedem Durchlauf eine Addition durch.
         {
            int v = 
               b[h - 1][2 * i].get(h, i) +
               b[h - 1][2 * i + 1].get(h, i);
            b[h][i].set(v);

            System.out.println("h: " + h + ", i: " + i + ", B[" + h + "][" + i + "] = B[" + (h - 1) + "][" + (2 * i) + "] + B[" + (h - 1) + "][" + (2 * i + 1) + "] = " + v);
         }
      }
   }
}
class P0
{
   public static void main(String[] args) 
   {      
      int[] a = {1, 2, 3, 4, 5, 6, 7, 8};          // Werte

      int n = a.length;                            // Anzahl der Werte in a = 8
      int logN = (int)(Math.log(n) / Math.log(2)); // log2(n), bei n = 8 => 3
      B[][] b = new B[logN + 1][n];                // [0 ... 3][0 ... 7]
      for(int i = 0; i < logN + 1; ++i)
      {
         for(int j = 0; j < n; ++j)
         {
            b[i][j] = new B();
         }
      }
      // h
      // 3                                                                   T0: B[3][0]
      //                                                            /             +             \
      // 2                               T0: B[2][0]                                                             T1: B[2][1]
      //                               /      +      \                                                         /      +      \
      // 1             T0: B[1][0]                         T1: B[1][1]                         T2: B[1][2]                         T3: B[1][3]
      //                /   +   \                           /   +   \                           /   +   \                           /   +   \
      // 0  T0: B[0][0]=A[0]  T1: B[0][1]=A[1]  T2: B[0][2]=A[2]  T3: B[0][3]=A[3]  T4: B[0][4]=A[4]  T5: B[0][5]=A[5]  T6: B[0][6]=A[6]  T7: B[0][7]=A[7]
      //
      // Legende: Ti ... Thread i
      
      System.out.println("n: " + n);
      System.out.println("logN: " + logN);
      
      T[] threads = new T[n];
      for(int i = 0; i < n; ++i) // zu jedem Wert 1 Thread
      {
         threads[i] = new T(i, a, b);
      }

      // Ausgabe:
      //System.out.println("Summe: " + b[logN][0].get());
   }
}
Aber leider liefert mir das eine IllegalMonitorStateException. Ist also alles falsch, was ich gemacht habe. Total falsches Konzept. Jetzt weiß ich nicht mehr weiter. :(

Wie macht man denn das richtig?
 
Zuletzt bearbeitet:

minzee

Bekanntes Mitglied
Ups, das ist mir jetzt peinlich. Ich habe nur "synchronized" vergessen bei den Methoden "get" und "set".

Scheint also so zu funktionieren:

Java:
class B 
{
   private int v;                 // Wert
   private boolean valid = false; // ob B schon einen Wert hat

   synchronized public void set(int v)
   {
      this.v = v;
      valid = true;
      
      notifyAll();
   }
   synchronized public int get(int h, int i)
   {
      while(!valid)
      {
         try
         {
            System.out.println("waiting h: " + h + ", i: " + i);
            wait();
         }
         catch(InterruptedException e)
         {
         }
      }
      return v;
   }
}
class T extends Thread
{
   private int i;
   private int[] a;
   private B[][] b;
   
   /**
    * @param int i Thread-ID >= 0
    * @param int[] a Daten
    * @param B[][] b Summen
    */
   public T(int i, int[] a, B[][] b)
   {
      this.i = i;
      this.a = a;
      this.b = b;
      
      start();
   }
   public void run()
   {
      System.out.println("i: " + i);
      
      int n = a.length;                            // Anzahl der Werte in a = 8
      int logN = (int)(Math.log(n) / Math.log(2)); // log2(n), bei n = 8 => 3
      
      b[0][i].set(a[i]);                           // unterste Reihe in der Baumstruktur (h = 0)
      for(int h = 1; h <= logN; ++h)               // Höhe. Bei n = 8 läuft jeder Thread von 0 bis 3.
      {
         if(i < n / Math.pow(2, h))                // Allerdings führt nich jeder Thread in jedem Durchlauf eine Addition durch.
         {
            int v = 
               b[h - 1][2 * i].get(h, i) +
               b[h - 1][2 * i + 1].get(h, i);
            b[h][i].set(v);

            System.out.println("h: " + h + ", i: " + i + ", B[" + h + "][" + i + "] = B[" + (h - 1) + "][" + (2 * i) + "] + B[" + (h - 1) + "][" + (2 * i + 1) + "] = " + v);
         }
      }
   }
}
class P0
{
   public static void main(String[] args) 
   {      
      int[] a = {1, 2, 3, 4, 5, 6, 7, 8};          // Werte

      int n = a.length;                            // Anzahl der Werte in a = 8
      int logN = (int)(Math.log(n) / Math.log(2)); // log2(n), bei n = 8 => 3
      B[][] b = new B[logN + 1][n];                // [0 ... 3][0 ... 7]
      for(int i = 0; i < logN + 1; ++i)
      {
         for(int j = 0; j < n; ++j)
         {
            b[i][j] = new B();
         }
      }
      // h
      // 3                                                                   T0: B[3][0]
      //                                                            /             +             \
      // 2                               T0: B[2][0]                                                             T1: B[2][1]
      //                               /      +      \                                                         /      +      \
      // 1             T0: B[1][0]                         T1: B[1][1]                         T2: B[1][2]                         T3: B[1][3]
      //                /   +   \                           /   +   \                           /   +   \                           /   +   \
      // 0  T0: B[0][0]=A[0]  T1: B[0][1]=A[1]  T2: B[0][2]=A[2]  T3: B[0][3]=A[3]  T4: B[0][4]=A[4]  T5: B[0][5]=A[5]  T6: B[0][6]=A[6]  T7: B[0][7]=A[7]
      //
      // Legende: Ti ... Thread i
      
      System.out.println("n: " + n);
      System.out.println("logN: " + logN);
      
      T[] threads = new T[n];
      for(int i = 0; i < n; ++i) // zu jedem Wert 1 Thread
      {
         threads[i] = new T(i, a, b);
      }

      // Ausgabe:
      for(int i = 0; i < n; ++i) // zu jedem Wert 1 Thread
      {
         try
         {
            threads[i].join();
         }
         catch(InterruptedException e)
         {
         }
      }
      System.out.println("Summe: " + b[logN][0].get(0, 0));
   }
}

Geht das vielleicht noch irgendwie einfacher?
 
Zuletzt bearbeitet:

minzee

Bekanntes Mitglied
Ich glaube, ich habe noch 2 Optimierungsmöglichkeiten gefunden:
Java:
class B 
{
   private int v;                 // Wert
   private boolean valid = false; // ob B schon einen Wert hat

   void init(int v)
   {
      this.v = v;
      valid = true;
   }
   /**
    * @param int v
    */
   synchronized void set(int v)
   {
      this.v = v;
      valid = true;
      
      notifyAll();
   }
   /**
    * @return int
    */
   synchronized int get(/*int h, int i*/) // h und i nur zum Debuggen
   {
      while(!valid)
      {
         try
         {
            //System.out.println("waiting h: " + h + ", i: " + i);
            wait();
         }
         catch(InterruptedException e)
         {
         }
      }
      return v;
   }
}
class T extends Thread
{
   private int i;
   private int[] a;
   private B[][] b;
   
   /**
    * @param int i Thread-ID >= 0
    * @param int[] a Daten
    * @param B[][] b Summen
    */
   public T(int i, int[] a, B[][] b)
   {
      this.i = i;
      this.a = a;
      this.b = b;
      
      start();
   }
   public void run()
   {
      //System.out.println("i: " + i);
      
      int n = a.length;                            // Anzahl der Werte in a = 8
      int logN = (int)(Math.log(n) / Math.log(2)); // log2(n), bei n = 8 => 3
      
      for(int h = 1; h <= logN; ++h)               // Höhe. Bei n = 8 läuft jeder Thread von 0 bis 3.
      {
         if(i < n / Math.pow(2, h))                // Allerdings führt nich jeder Thread in jedem Durchlauf eine Addition durch.
         {
            int v = 
               b[h - 1][2 * i].get(/*h, i*/) +
               b[h - 1][2 * i + 1].get(/*h, i*/);
            b[h][i].set(v);

            //System.out.println("h: " + h + ", i: " + i + ", B[" + h + "][" + i + "] = B[" + (h - 1) + "][" + (2 * i) + "] + B[" + (h - 1) + "][" + (2 * i + 1) + "] = " + v);
         }
      }
   }
}
class P
{
   private static void initB(int[] a, B[][] b, int n, int logN)
   {
      for(int i = 0; i < n; ++i)
      {
         b[0][i] = new B();
         b[0][i].init(a[i]);
      }
      for(int h = 1; h < logN + 1; ++h) // 1, 2, 3
      {
         n /= 2;
         for(int i = 0; i < n; ++i) // 4, 2, 1
         {
            b[h][i] = new B();
         }
      }
   }
   public static void main(String[] args) 
   {      
      int[] a = {1, 2, 3, 4, 5, 6, 7, 8};          // 2^x Werte

      // Initialisierung:
      int n = a.length;                            // Anzahl der Werte in a = 8
      int logN = (int)(Math.log(n) / Math.log(2)); // log2(n), bei n = 8 => 3
      B[][] b = new B[logN + 1][n];                // [0 ... 3][0 ... 7]
      initB(a, b, n, logN);
      
      // h
      // 3                                                       T0: B[3][0]
      //                                                /             +             \
      // 2                         T0: B[2][0]                                                 T1: B[2][1]
      //                         /      +      \                                             /      +      \
      // 1          T0: B[1][0]                   T1: B[1][1]                   T2: B[1][2]                   T3: B[1][3]
      //             /   +   \                     /   +   \                     /   +   \                     /   +   \
      // 0  B[0][0]=A[0]   B[0][1]=A[1]   B[0][2]=A[2]   B[0][3]=A[3]   B[0][4]=A[4]   B[0][5]=A[5]   B[0][6]=A[6]   B[0][7]=A[7]
      //
      // Legende: Ti ... Thread i
      
      //System.out.println("n: " + n);
      //System.out.println("logN: " + logN);
      
      T[] threads = new T[logN + 1];
      for(int i = 0; i <= logN; ++i)
      {
         threads[i] = new T(i, a, b);
      }

      // Ausgabe:
      for(int i = 0; i <= logN; ++i)
      {
         try
         {
            threads[i].join();
         }
         catch(InterruptedException e)
         {
         }
      }
      System.out.println("Summe: " + b[logN][0].get(/*0, 0*/));      
   }
}
Allerdings schaut die Implementierung jetzt ein wenig anders aus als der Algorithmus. Die b[0]-Werte initialisiere ich jetzt nicht mehr im Thread, sondern schon vorher im Hauptprogramm. Dadurch kann ich die Anzahl der Threads reduzieren.

Ich hoffe, das verursacht keine Probleme.?.?
 

minzee

Bekanntes Mitglied
Ich glaube, diese Variante ist doch nicht gut. Das Wichtigste ist hier die Performance. Das Programm soll schneller sein als ein paar Additionen. Doch je mehr ich außerhalb der Threads mache, desto langsamer wird automatisch alles.

Vielleicht kann das Programm nur schneller werden als normale Additionen, wenn ich auch noch die b-Instanzierungen irgendwie in die Threads reinbekomme.
 
Zuletzt bearbeitet:

arilou

Bekanntes Mitglied
Doch je mehr ich außerhalb der Threads mache, desto langsamer wird automatisch alles.
Unsinn.

Dir ist schon klar, dass das eine akademische Programmierübung darstellt?

Du wirst extrem viele Additionen benötigen, um mit Threads eine Beschleunigung zu erreichen.
In der Zeit, die ein 'new' verbrät, um ein neues Thread-Objekt anzulegen, kannst du 1 Mio Additionen durchführen. Und da du ein Array aufsummieren willst... bei einer Datenmenge, die da noch deutlich darüber liegt, ist dein Problem weniger die Rechengeschwindigkeit der Prozessorkerne, sondern die Speicherbandbreite. Das Ram kann solche Datenmengen nicht schnell genug liefern, nicht mal für 1 Prozessorkern.

Ohne Datenlokalität (d.h. dass ein und dieselben Daten immer wieder verwendet werden, so dass dir ein Cache etwas bringt) kannst du Multithreading vergessen.
 
Zuletzt bearbeitet:

minzee

Bekanntes Mitglied
Kann man das irgendwie anders programmieren, damit das auch bei Arrays Sinn macht, die keine millionen Einträge hat?

Die ersten paar Algorithmen, die in der erwähnten pdf erklärt werden, funktionieren nämlich scheinbar alle irgendwie nach dem gleichen Prinzip.
 
Zuletzt bearbeitet:

minzee

Bekanntes Mitglied
Mir spukt da was im Kopf herum.

Ist das richtig, dass man dem Datentyp int kein null übergeben kann, dem Datentyp Integer aber schon? Könnte ich dann auf null prüfen, wenn ich kontrollieren will, ob ein b-Wert valide ist? Dann könnte ich mir nämlich die Eigenschaft valid sparen.

Und dieses ganze synchronize muss doch nicht unbedingt bei einer Methode angegeben werden, richtig? Man kann doch auch irgendwo mitten im Code einen synchronize-Block definieren, glaube ich irgendwo mal gelesen zu haben.

Aufgrund dieser 2 Punkte brächte ich dann keine B-Klasse und könnte ich mir doch die ganzen B-Instanzierungen ersparen, stimmt das?
 
Zuletzt bearbeitet:

arilou

Bekanntes Mitglied
'int' ist ein primitiver Datentyp, und selbige können alle nicht 'null' sein.
java.lang.Integer ist eine Klasse, und eine Variable diesen "Typs" ist eine Referenz (ein "Pointer") auf ein Integer-Objekt. Ein Pointer kann auf 'null' gesetzt werden.

Die 'null' -Idee, um die Variable "valid" zu sparen, funktioniert prinzipiell. Aber mit Objekten zu hantieren ist viel langsamer als mit primitiven Datentypen...
 

minzee

Bekanntes Mitglied
War leider sowieso eine dumme Idee von mir. Definiert man synchronized als Block, muss man ein Objekt übergeben. D. h. auch wenn ein b-Wert noch invalide ist, sollte er schon ein Integer sein.

Ich befürchte, jetzt bin ich mit meinem Latein am Ende. :( Das wurmt mich echt. Aber man muss auch mal verlieren können.

Falls ihr keine Ideen mehr habt, lasse ich das Thema ruhen. Vielleicht stoße ich irgendwann zufällig auf einen Code, der diesen ganzen parallelen Aufwand rechtfertigt.
 
Zuletzt bearbeitet:

minzee

Bekanntes Mitglied
Ich bin ein großer Bücher-Fan! Danke für den Hinweis :)

Nebenläufige & verteilte Programmierung - terrashop.de
Für die Bearbeitung des Online-Kurses werden ca. 60 Stunden benötigt
Weißt du zufällig, von welchem Online-Kurs genau hier die Rede ist? Würde mir gerne eine wenig davon ansehen. Wenn es mir gefällt, kaufe ich mir das Buch und gehe dann den Online-Kurs komplett durch.

Ist der irgendwo auf F versteckt?

Registriert habe ich mich. Kurs habe ich gefunden auf W3L-B . Die tan 5185441337 habe ich eingelöst. Aber mir wird zum Kurs kein Inhaltsverzeichnis angelegt. Alles leer :(

Wie kann ich Wissensbausteine auswählen? Kann ich die nur auswählen, wenn ich vorher W3L-Online-Kurse: Java: Nebenl die 890 euro bezahlt habe?
 
Zuletzt bearbeitet:

JavaMeister

Gesperrter Benutzer
Hi,

Ich habe das w3l vor Jahren genutzt. Da wurden für die Studenten die Unterlagen bereitgestellt.

Wie dem auch sei. Ich gehe davon aus, dass die Inhalte sichtbar werden, wenn man sie bezahlt.

Außerdem würde ich mich in diesem fall an w3l direkt wenden.
 

minzee

Bekanntes Mitglied
Ich habe vielleicht eine Lösung gefunden:
Java:
class SumCounter
{
   private int n;
   private int i; // Zähler je Ebene
   
   /**
    * @param int n Anzahl der Knoten auf der Ebene über der untersten Ebene = Anzahl Werte / 2 = Anzahl Threads.
    */
   SumCounter(int n)
   {
      this.n = n;
      i = 0;
   }
   synchronized void inc()
   {
      try
      {
         if(i < n - 1)
         {
            ++i;
            wait(); // Thread, der inc aufgerufen hat, in Wartepool legen
         }
         else if(n > 1)
         {
            n /= 2;
            i = 0;
            notifyAll(); // alle Threads aus Wartepool holen
         }
      }
      catch( InterruptedException e)
      {
         System.out.println("FEHLER");
      }
   }
}
class SumThread extends Thread
{
   private int i;
   private int n;
   private int[][] sumValues;
   private SumCounter c;
   
   /**
    * @param int n Summations-Ebenen
    * @param int i Thread-ID
    * @param int[][] sumValues aufzusummierende Daten
    * @param SumCounter c
    */
   SumThread(int n, int i, int[][] sumValues, SumCounter c)
   {
      this.n = n;
      this.i = i;
      this.sumValues = sumValues;
      this.c = c;
      
      start();
   }
   public void run()
   {
      int left = i * 2;
      int right = left + 1;
      for(int j = n - 1; j >= 0; --j) // Zeilen
      {
         if(i < 1 << j)
         {
            sumValues[j][i] = sumValues[j + 1][left] + sumValues[j + 1][right];
            c.inc();
         }
      }
   }
}
class ThreadMath
{
   static int sum(int[] values)
   {
      // Daten in 2-dim. Array übernehmen:
      int n = (int)(Math.log(values.length) / Math.log(2.0)); // log2(n), bei n = 8 => 3
      int[][] sumValues = new int[n + 1][values.length]; // [Zeile][Spalte]
      sumValues[n] = values;

      // SumCounter zur Synchronisation der Additionen:
      int m = values.length / 2;
      SumCounter sumCounter = new SumCounter(m);

      // Threads:
      SumThread[] sumThreads = new SumThread[m];
      for(int i = m; i > 0; )
      {
         sumThreads[--i] = new SumThread(n, i, sumValues, sumCounter);
      }
      try
      {
         sumThreads[0].join(); // darauf warten, dass Thread 0 fertig ist
      }
      catch( InterruptedException e)
      {
         System.out.println("FEHLER");
      }
      
      // Debugging-Ausgabe:
      for(int row = 0; row <= n; ++row)
      {
         for(int col = 0; col < values.length; ++col)
            System.out.print(sumValues[row][col] + " ");
         System.out.println();
      }
      
      // Summe:
      return sumValues[0][0];
   }
}
class Main
{
   public static void main(String[] args)
   {
      int[] values = {1, 2, 3, 4, 5, 6, 7, 8}; // 2^x Werte    
      int sum = ThreadMath.sum(values);
      System.out.println(sum); // 36
   }
}
Ich habe jetzt ganz normale int-Werte. Mache also nicht für jeden Wert ein eigenes Objekt. Die Synchronisation übernimmt jetzt eine eigene Klasse, die immer je Baumebene zählt, wie viele Additionen schon durchgeführt wurden.

Ist das OK so?
 
Zuletzt bearbeitet:

minzee

Bekanntes Mitglied
Ich nehme das zurück. Das ist wohl auch keine Lösung. Da bei jeder Addition die synchronisierte Methode aufgerufen wird, und dabei der Thread fast immer in den Wartepool gelegt wird, wird hier wohl wieder serialisiert. Dadurch gehen die Vorteile der parallelen Programmierung verloren. Ist doch so, oder?
 
Ä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
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
P Threads Methode von Threads erledigen lassen Java Basics - Anfänger-Themen 11

Ähnliche Java Themen

Neue Themen


Oben