Thread(Group)-Frage

Status
Nicht offen für weitere Antworten.

Reality

Top Contributor
Hi,
dieser Quelltext gibt folgendes aus:
Task 0: start
Task 1: start
Task 2: start
Task 3: start
Task 0: end
Task 4: start
Task 1: end
Task 5: start
Task 2: end
Task 6: start
Task 3: end
Task 7: start
Task 4: end
Task 5: end
Task 6: end
Task 7: end

Code:
import java.util.LinkedList;

/*A thread pool is a group of a limited number of threads that
are used to execute tasks.
*/

public class ThreadPool extends ThreadGroup{
  private boolean isAlive;
  private LinkedList taskQueue;
  private int threadID;
  private static int threadPoolID;

  public ThreadPool(int numThreads){
    super("ThreadPool "+ (threadPoolID++));
    setDaemon(true);
    isAlive = true;

    taskQueue = new LinkedList();
    for(byte i = 0; i < numThreads; i++){
      new PooledThread().start();
    }
  }

  public synchronized void runTask(Runnable task){
    if(!isAlive)
      throw new IllegalArgumentException();

    if(task != null){
      taskQueue.add(task);
      notify();
    }
  }

  protected synchronized Runnable getTask() throws InterruptedException{
    while(taskQueue.size() == 0){
      if(!isAlive){
        return null;
      }
      wait();
    }
    return (Runnable) taskQueue.removeFirst();
  }

  /* Closes this ThreadPool and return ummediately. All threads are stopped
  , and waiting tasks are not executed. Once a ThreadPool is closed, no more
  tasks can be run in this ThreadPool */

  public synchronized void close(){
    if(isAlive){
      isAlive = false;
      taskQueue.clear();
      interrupt();
    }
  }

  /*Closes this ThreadPool and waits for all running threads to finish.
  Any waiting tasks are executed */

  public void join(){
    //notify all waitings Threads that this ThreadPool is no longer alive
    synchronized(this){
      isAlive = false;
      notifyAll();
    }

    //wait for all Threads to finish
    Thread threads[] = new Thread[activeCount()];
    int count = enumerate(threads);

    for(byte i = 0; i < count; i++){
      try{
        threads[i].join();
      }catch(InterruptedException ex){}
    }
  }

  private class PooledThread extends Thread{
    public PooledThread(){
      super(ThreadPool.this, "Pooled Thread-" + (threadID++));
    }

    public void run(){
      while(!isInterrupted()){
        //get a task to run
        Runnable task = null;
        try{
          task = getTask();
        }catch(InterruptedException ex){}

        //if getTask() returned null or was interrupted, close this thread
        //by returning.

        if(task == null)
          return;

        //run the task, and eat anay exceptions it throws
        try{
          task.run();
        }catch(Throwable t){
          uncaughtException(this, t);
        }
      }
    }
}

}

Code:
public class ThreadPoolTest {
  public static void main(String[] args) {
    if(args.length != 2){
      System.out.println("Test the Thread Pool task.");
      System.out.println("Usage: java ThreadPoolTest numTask numThreads");
      return ;
    }
      int numTasks = Integer.parseInt(args[0]);  // Wert 8 wird übergeben
      int numThreads = Integer.parseInt(args[1]); // Wert 4 wird übergeben

      //create the thread pool
      ThreadPool threadPool = new ThreadPool(numThreads);
      //run example Task
      for( int i = 0; i < numTasks; i++)
        threadPool.runTask(createTask(i));

        //close the pool und wait for all tasks to finish.
      threadPool.join();

  }

  /*Creates a simple Runnable that prints an ID, waits 500 milliseconds,
  then prints the ID again. */

  private static Runnable createTask(final int taskID){
    return new Runnable(){
      public void run(){
        System.out.println("Task "+ taskID + ": start");

        //simulate a long-running task
        try{
          Thread.sleep(500);
        }catch(InterruptedException ex){}

        System.out.println("Task "+ taskID + ": end");
      }
    };
  }
}

Nun verstehe ich nicht, wo der Code-Abschnitt ist, der sagt, dass immer nur 4 Tasks gleichzeitig laufen können und falls einer fertig ist, gleich der nächste Task ausgeführt wird.

Liebe Grüße
Real
 
B

Beni

Gast
Hier ist der eine Teil:
Code:
    for(byte i = 0; i < numThreads; i++){
      new PooledThread().start();

Der andere ist hier:
Code:
  private class PooledThread extends Thread{
    public void run(){
      while(!isInterrupted()){
         ....
        //run the task, and eat anay exceptions it throws
        try{
          task.run();

Der PooledThread startet keinen zusätzlichen Thread, er ruft nur die Methode "run" auf. Das bedeutet, dass jeder PooledThread genau ein Task auf einmal abarbeiten kann. Und da es 4 PooledThreads gibt...
 

Reality

Top Contributor
Ja 4 PooledThreads, aber 8 Tasks. ???:L
Es laufen immer 4 Tasks gleichzeitg. Wenn der 1. Task fertig ist, wird der 5 aufgerufen usw.

Ich versteh das immernoch nicht. :oops:

Liebe Grüße
Real
 
B

Beni

Gast
Hm, ein Task ist ja eigentlich nur eine Methode "run", die gar nichts spezielles macht. Wenn man eine normale Methode aufruft, kommt man erst zurück, wenn die Methode all ihre Befehle abgearbeitet hat.

Jetzt ruft so ein PooledThread eine dieser Methoden auf. Er bleibt solange in der Methode, bis sie total abgearbeitet ist, dann ruft er die nächste auf.

Setz mal "numThreads=1" und beobachte was der PooledThread dann macht (bau ein paar "System.out.println..." ein, oder nimm ein Debugger). Du wirst sehen, er hat gar keinen Grund mehrere Tasks auf einmal auszuführen.
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
Leyla Thread isInterrupt Java Basics - Anfänger-Themen 18
P Meldung aus Java-Klasse in Thread an aufrufende Klasse Java Basics - Anfänger-Themen 1
A Thread XML-Dateien zusammenfügen Java Basics - Anfänger-Themen 11
F influxdb Upload in eigenem Thread Java Basics - Anfänger-Themen 2
frager2345 Thread - Methoden synchronized deklarieren Java Basics - Anfänger-Themen 10
berserkerdq2 Größter unterschied von extends thread und implements runnable? Java Basics - Anfänger-Themen 2
T Thread beenden aus zweiter Klasse Java Basics - Anfänger-Themen 4
A Thread - Synchronized Java Basics - Anfänger-Themen 10
A Thread Producer - Consumer Java Basics - Anfänger-Themen 1
A Thread-Semhapore Java Basics - Anfänger-Themen 0
A Thread Exchanger Java Basics - Anfänger-Themen 22
A Thread-Cyclicbarrier Java Basics - Anfänger-Themen 4
B In einem Thread Endlosschleife beenden Java Basics - Anfänger-Themen 19
A Thread-Verklemmung Java Basics - Anfänger-Themen 10
A Thread-Schreibe-Lese-Problem Java Basics - Anfänger-Themen 4
A Thread find number Java Basics - Anfänger-Themen 8
F Thread.sleep() Java Basics - Anfänger-Themen 5
F Exception in thread "main" java.lang.ArrayIndexOutOfBoundsException: 11 at main.main(main.java:11) Java Basics - Anfänger-Themen 2
A Thread Java Basics - Anfänger-Themen 3
M Exception in thread "main" java.util.NoSuchElementException Java Basics - Anfänger-Themen 2
A Thread Java Basics - Anfänger-Themen 8
B Compiler-Fehler Fehlermeldung Exception in thread, falsche Eingabewert Java Basics - Anfänger-Themen 2
M Thread-Zustände Java Basics - Anfänger-Themen 6
CptK For-Schleife in Thread nach jedem Durchlauf pausieren Java Basics - Anfänger-Themen 35
S Kriege Fehler "Exception in thread" beim Benutzen von SubStrings. Java Basics - Anfänger-Themen 2
B Endlosschleife Thread sauber beenden Java Basics - Anfänger-Themen 19
D Java Thread wartet nur ein mal Java Basics - Anfänger-Themen 1
D Java Thread wartet nur ein mal Java Basics - Anfänger-Themen 0
O Exception in thread "main" java.lang.ArithmeticException: / by zero Java Basics - Anfänger-Themen 4
C Thread und TimerTask, Verstädnisproblem Java Basics - Anfänger-Themen 10
amgadalghabra Sorting Thread Launcher Java Basics - Anfänger-Themen 3
B Exception in thread "AWT-EventQueue-0" java.util.ConcurrentModificationException Java Basics - Anfänger-Themen 8
A Thread Java Basics - Anfänger-Themen 4
A Thread Java Basics - Anfänger-Themen 1
A Thread Java Basics - Anfänger-Themen 0
R Exception in thread "main" java.lang.ArrayIndexOutOfBoundsException Java Basics - Anfänger-Themen 5
S Compiler-Fehler Exception in thread "main" java.lang.Error: Unresolved compilation problem: Java Basics - Anfänger-Themen 6
L Liste in anderem Thread laden Java Basics - Anfänger-Themen 1
B Thread / Prozess stoppen? Java Basics - Anfänger-Themen 22
I Compiler-Fehler Exception in thread "main" java.lang.ArrayIndexOutOfBoundsException: 5 Java Basics - Anfänger-Themen 3
B Threads Thread sleep() Method einfache Frage Java Basics - Anfänger-Themen 8
W Thread Aufgabe - Vorgehensweise Java Basics - Anfänger-Themen 8
L Liste in anderem Thread laden Java Basics - Anfänger-Themen 0
J Threads PrograssBar update während thread Java Basics - Anfänger-Themen 13
D Compiler-Fehler Wert auf Datenbank übertragen und Sleep Thread Java Basics - Anfänger-Themen 3
Spencer Reid JavaFX Memory Thread.sleep Java Basics - Anfänger-Themen 1
S Thread.sleep mit JProgressBar Java Basics - Anfänger-Themen 1
ralfb1105 Frage zu Thread Synchronisation mit wait() und notify() Java Basics - Anfänger-Themen 3
R Exception in thread "main" java.lang.NullPointerException Java Basics - Anfänger-Themen 10
J JavaFX -> SocketIO -> Thread -> Update Label Java Basics - Anfänger-Themen 13
J Thread Handling Java Basics - Anfänger-Themen 9
A Problem mit Thread.sleep Java Basics - Anfänger-Themen 4
C Thread in Methode + raus aus der Schleife Java Basics - Anfänger-Themen 10
E Threads Thread in While-Schleife nur einmal starten Java Basics - Anfänger-Themen 2
F Daten von Thread an den aufrufenden zurückgeben Java Basics - Anfänger-Themen 22
C Compiler-Fehler Exception in thread "main" java.lang.ArrayIndexOutOfBoundsException: 2 Java Basics - Anfänger-Themen 3
B Thread Problem Java Basics - Anfänger-Themen 7
N KeyListener in Thread Java Basics - Anfänger-Themen 0
M Thread.sleep() Funktion Java Basics - Anfänger-Themen 1
W JLabel in Main aus Thread verändern. Java Basics - Anfänger-Themen 4
D Ausgeben welcher Thread gerade Arbeitet Java Basics - Anfänger-Themen 8
N Threads Thread-Fehler Java Basics - Anfänger-Themen 2
F Thread um Uhrzeit ausführen Java Basics - Anfänger-Themen 5
F Get/Post als eigener Thread mit Rückgabe Java Basics - Anfänger-Themen 5
J Exception in thread "main" Java Basics - Anfänger-Themen 1
F Thread der auf eine Queue wartet, sicher beenden Java Basics - Anfänger-Themen 4
B Animation mit Thread(s) Java Basics - Anfänger-Themen 23
I Thread.sleep (1000); Java Basics - Anfänger-Themen 1
M Threads Jede Klasse einem Thread zuweisen Java Basics - Anfänger-Themen 7
J Java Thread cancel() und wiederbeleben Java Basics - Anfänger-Themen 4
J BouncingBalls 1 Thread Java Basics - Anfänger-Themen 3
L Fehler: Exception in thread "main" java.lang.ArrayIndexOutOfBoundsException Java Basics - Anfänger-Themen 4
J Timer oder Thread programmieren ? Java Basics - Anfänger-Themen 10
fLooojava Laufender Thread | Boolean ändern Java Basics - Anfänger-Themen 9
T Thread Pool mit Work Stealing Java Basics - Anfänger-Themen 1
R Java Thread Java Basics - Anfänger-Themen 10
J Welche Methoden laufen im neuen thread ?? Java Basics - Anfänger-Themen 9
S Java memory fehler: Exception in thread "AWT-EventQueue-0" java.lang.OutOfMemoryError: Java heap spa Java Basics - Anfänger-Themen 5
K Thread - Methoden in die run Methode Schreiben Java Basics - Anfänger-Themen 5
N Threads Exception in thread "main"... Feher bei dem Versuch ein Radius zu berechnen Java Basics - Anfänger-Themen 4
A Code läuft nicht, Fehlermeldung Exception in thread "main" java.lang.Error: Unresolved compilation " Java Basics - Anfänger-Themen 11
V Threads Exception in Thread behandeln Java Basics - Anfänger-Themen 3
S Methoden Multi-Thread und Methoden Objects. Java Basics - Anfänger-Themen 1
J Thread erstellen (BlueJ Projekt) Java Basics - Anfänger-Themen 3
P Exception in thread "main" java.lang.NoClassDefFoundError: Java Basics - Anfänger-Themen 1
F Threads Variable aus einem Thread in main Methode? Java Basics - Anfänger-Themen 9
K Exception in thread "main" Java Basics - Anfänger-Themen 7
L Thread-Frage Java Basics - Anfänger-Themen 2
E Was ist ein idle-thread? Java Basics - Anfänger-Themen 1
D Exception in thread "AWT-EventQueue-0" Java Basics - Anfänger-Themen 8
J Threads Prozess in Thread auslagern Java Basics - Anfänger-Themen 2
G Thread mehrmals starten und schliessen Java Basics - Anfänger-Themen 6
F Thread Koordination (Vorteile/Nachteile) Java Basics - Anfänger-Themen 0
O Thread aus dem Thread stoppen Java Basics - Anfänger-Themen 6
O Swingworker/Thread Java Basics - Anfänger-Themen 3
R Focus auf JPanel im Thread Java Basics - Anfänger-Themen 9
S musik in eigenem thread Java Basics - Anfänger-Themen 2
A Klasse,Vererbung,Interface,Singleton,Thread Java Basics - Anfänger-Themen 5
IngoF GUI mit Thread Daten austauschen. Java Basics - Anfänger-Themen 6
L Compiler-Fehler Exception in thread "main" java.lang.NullPointerException Java Basics - Anfänger-Themen 2

Ähnliche Java Themen

Neue Themen


Oben