Threads Multithreading Threads sollen warten

B

Bungeefan

Gast
Hey ich habe ein Probelm mit meinem Checksum Programm.
Es werden mit mehreren Threads die Checksummen der Dateien gleichzeitig berechnet.
Jetzt habe ich aber das Problem das er bestimmte Buttons in der GUI erst wieder enablen soll wenn ALLE fertig sind.
Ich hab schon was mit wait() und notify() probiert aber da blicke ich nicht ganz durch.
Wäre nett wenn mit jemand helfen könnte.
Java:
btnBrowse.setEnabled(false);
                    btnCopyMD2.setEnabled(false);
                    btnCopyMD5.setEnabled(false);
                    btnCopySHA_1.setEnabled(false);
                    btnCopySHA_256.setEnabled(false);
                    btnCopySHA_384.setEnabled(false);
                    btnCopySHA_512.setEnabled(false);
                    btnCopyAll.setEnabled(false);
                    btnVerify.setEnabled(false);
                    btnVerify.setEnabled(false);
                    chckbxMD2.setEnabled(false);
                    chckbxMD5.setEnabled(false);
                    chckbxSHA1.setEnabled(false);
                    chckbxSHA256.setEnabled(false);
                    chckbxSHA384.setEnabled(false);
                    chckbxSHA512.setEnabled(false);
                    try {
                        new Thread(new Runnable() {

                            @Override
                            public void run() {

                                if (chckbxMD2.isSelected()) {
                                    generateHash.add(barMD2);
                                    barMD2.setIndeterminate(true);
                                    generateHash.revalidate();
                                    generateHash.repaint();
                                    try {
                                        Checksum_Utility.instance.md2 = Checksum_Utility.instance.createMD2(datei);
//Berechnet Checksumme
                                    } catch (NoSuchAlgorithmException | IOException e) {
                                        e.printStackTrace();
                                    }
                                    barMD2.setIndeterminate(false);
                                    generateHash.remove(barMD2);
                                    generateHash.revalidate();
                                    generateHash.repaint();
                                    fieldMD2.setEnabled(true);
                                    fieldMD2.setText(Checksum_Utility.instance.md2);
                                    btnCopyMD2.setEnabled(true);
                                }
                                chckbxMD2.setEnabled(true);
                                this.notify();
                            }
                        }).start();
                        new Thread(new Runnable() {

                            @Override
                            public void run() {
                                if (chckbxMD5.isSelected()) {
                                    generateHash.add(barMD5);
                                    barMD5.setIndeterminate(true);
                                    try {
                                        Checksum_Utility.instance.md5 = Checksum_Utility.instance.createMD5(datei);
//Berechnet Checksumme
                                    } catch (NoSuchAlgorithmException | IOException e) {
                                        e.printStackTrace();
                                    }
                                    barMD5.setIndeterminate(false);
                                    generateHash.remove(barMD5);
                                    fieldMD5.setEnabled(true);
                                    fieldMD5.setText(Checksum_Utility.instance.md5);
                                    btnCopyMD5.setEnabled(true);
                                }
                                chckbxMD5.setEnabled(true);
                            }
                        }).start();
                        new Thread(new Runnable() {

                            @Override
                            public void run() {
                                if (chckbxSHA1.isSelected()) {
                                    generateHash.add(barSHA1);
                                    barSHA1.setIndeterminate(true);
                                    try {
                                        Checksum_Utility.instance.sha1 = Checksum_Utility.instance.createSHA1(datei);
//Berechnet Checksumme
                                    } catch (NoSuchAlgorithmException | IOException e) {
                                        e.printStackTrace();
                                    }
                                    barSHA1.setIndeterminate(false);
                                    generateHash.remove(barSHA1);
                                    fieldSHA1.setEnabled(true);
                                    fieldSHA1.setText(Checksum_Utility.instance.sha1);
                                    btnCopySHA_1.setEnabled(true);
                                }
                                chckbxSHA1.setEnabled(true);
                            }
                        }).start();
                        new Thread(new Runnable() {

                            @Override
                            public void run() {
                                if (chckbxSHA256.isSelected()) {
                                    generateHash.add(barSHA256);
                                    barSHA256.setIndeterminate(true);
                                    try {
                                        Checksum_Utility.instance.sha256 = Checksum_Utility.instance
                                                .createSHA256(datei);
//Berechnet Checksumme
                                    } catch (NoSuchAlgorithmException | IOException e) {
                                        e.printStackTrace();
                                    }
                                    barSHA256.setIndeterminate(false);
                                    generateHash.remove(barSHA256);
                                    fieldSHA256.setEnabled(true);
                                    fieldSHA256.setText(Checksum_Utility.instance.sha256);
                                    btnCopySHA_256.setEnabled(true);
                                }
                                chckbxSHA256.setEnabled(true);
                            }
                        }).start();
                        new Thread(new Runnable() {

                            @Override
                            public void run() {
                                if (chckbxSHA384.isSelected()) {
                                    generateHash.add(barSHA384);
                                    barSHA384.setIndeterminate(true);
                                    try {
                                        Checksum_Utility.instance.sha384 = Checksum_Utility.instance
                                                .createSHA384(datei);
//Berechnet Checksumme
                                    } catch (NoSuchAlgorithmException | IOException e) {
                                        e.printStackTrace();
                                    }
                                    barSHA384.setIndeterminate(false);
                                    generateHash.remove(barSHA384);
                                    fieldSHA384.setEnabled(true);
                                    fieldSHA384.setText(Checksum_Utility.instance.sha384);
                                    btnCopySHA_384.setEnabled(true);
                                }
                                chckbxSHA384.setEnabled(true);
                            }
                        }).start();
                        Thread th = new Thread(new Runnable() {

                            @Override
                            public void run() {
                                if (chckbxSHA512.isSelected()) {
                                    generateHash.add(barSHA512);
                                    barSHA512.setIndeterminate(true);
                                    try {
                                        Checksum_Utility.instance.sha512 = Checksum_Utility.instance
                                                .createSHA512(datei);
//Berechnet Checksumme
                                    } catch (NoSuchAlgorithmException | IOException e) {
                                        e.printStackTrace();
                                    }
                                    barSHA512.setIndeterminate(false);
                                    generateHash.remove(barSHA512);
                                    fieldSHA512.setEnabled(true);
                                    fieldSHA512.setText(Checksum_Utility.instance.sha512);
                                    btnCopySHA_512.setEnabled(true);
                                }
                                chckbxSHA512.setEnabled(true);
                            }
                        });
                        th.start();
                        Checksum_Utility.instance.wait();
//--------------------------------------------------------------
                        btnCopyAll.setEnabled(true);
                        btnBrowse.setEnabled(true);
                        btnVerify.setEnabled(true);
//--------------------------------------------------------------
//Das hier soll erst ausgeführt werden wenn ALLE Checksummen berechnet (und angezeigt werden)
                    } catch (Exception e) {
                        e.printStackTrace();
                    }
 

DrZoidberg

Top Contributor
Also der Code der einzelnen Threads ist sehr ähnlich. Das lässt sich bestimmt stark kürzen indem du eine Methode schreibst, die einen neuen Thread startet.
Anstelle von wait und notify würde ich einen CountDownLatch verwenden.
 

DrZoidberg

Top Contributor
Du musst latch.await() in einem anderen Thread ausführen. Allerdings solltest du dann auch SwingUtilities.invokeLater() verwenden um Updates an deiner GUI im korrekten Thread auszuführen.
 

fhoffmann

Top Contributor
DrZoidberg schrieb bereits in seinem ersten Beitrag
Also der Code der einzelnen Threads ist sehr ähnlich.
Du solltest zunächst lernen, solche Code-Verdoppelungen zu vermeiden (egal ob du "Anfänger" oder "Amateur" bist).
Wenn du das gelernt hast, können wir ernsthaft über Threads sprechen.

Damit ich nicht missverstanden werde: Wir helfen dir natürlich gerne!
 
Zuletzt bearbeitet:
B

Bungeefan

Gast
Könntest du bitte ein Codebeispiel dazu bringen wie ich das vermeiden kann, mir fällt dazu leider nichts ein. Grundsätzlich ist mir klar das das eine unschöne Lösung ist aber ich bisher keine andere hatte.
 
Zuletzt bearbeitet von einem Moderator:

Flown

Administrator
Mitarbeiter
Hier mal wie Swingworker und CompletableFutures zusammenarbeiten könnten.
Java:
import javax.swing.*;
import java.util.List;
import java.util.concurrent.CompletableFuture;
import java.util.concurrent.ThreadLocalRandom;
import java.util.stream.IntStream;

public class Test {

  public static void main(String... args) {
    MyUI.start();
  }
}

class MyUI {

  private MyUI() {
    init();
  }

  private void init() {
    JFrame frame = new JFrame("Thread-Test");
    frame.setDefaultCloseOperation(WindowConstants.EXIT_ON_CLOSE);
    frame.setLocationByPlatform(true);

    JPanel mainPanel = new JPanel();
    mainPanel.setLayout(new BoxLayout(mainPanel, BoxLayout.Y_AXIS));

    JPanel boxPanel = new JPanel();
    JCheckBox[] checkBoxes = new JCheckBox[3];
    for(int i = 0; i < checkBoxes.length; i++) {
      checkBoxes[i] = new JCheckBox();
      boxPanel.add(checkBoxes[i]);
    }

    mainPanel.add(boxPanel);

    DefaultListModel<String> listModel = new DefaultListModel<>();
    JList<String> finishedList = new JList<>(listModel);

    JButton startCalculation = new JButton("Start");
    startCalculation.addActionListener(e -> {
      startCalculation.setEnabled(false);
      listModel.clear();
      SwingWorker<Void, String> mySwingWorker = new SwingWorker<Void, String>() {
        @Override
        protected Void doInBackground() throws Exception {
          CompletableFuture<?>[] collect = IntStream.range(0, checkBoxes.length).filter(i -> checkBoxes[i].isSelected())
            .mapToObj(i -> CompletableFuture.runAsync(Caluclations::calculate).thenAccept(x ->
              publish(Integer.toString(i))))
            .toArray(CompletableFuture<?>[]::new);
          CompletableFuture.allOf(collect).join();
          return null;
        }

        @Override
        protected void process(List<String> chunks) {
          chunks.forEach(listModel::addElement);
        }

        @Override
        protected void done() {
          startCalculation.setEnabled(true);
        }
      };
      mySwingWorker.execute();

    });

    mainPanel.add(finishedList);
    mainPanel.add(startCalculation);

    frame.add(mainPanel);

    frame.pack();
    frame.setVisible(true);
  }


  public static void start() {
    SwingUtilities.invokeLater(MyUI::new);
  }
}

class Caluclations {
  public static void calculate() {
    try {
      Thread.sleep(ThreadLocalRandom.current().nextInt(100, 5000));
    } catch (InterruptedException e) {
      e.printStackTrace();
    }
  }
}
Soviele Häkchen gesetzt werden, so viele Threads werden gestartet und der Button wird disabled bis alle Berechnungen fertig sind.
 

DrZoidberg

Top Contributor
Könntest du bitte ein Codebeispiel dazu bringen wie ich das vermeiden kann, mir fällt dazu leider nichts ein. Grundsätzlich ist mir klar das das eine unschöne Lösung ist aber ich bisher keine andere hatte.

Du kannst die ganzen graphischen Komponenten in Objekt bzw. Arrays stecken, um sie in einer Schleife abarbeiten zu können.
Das könnte dann z.B. so aussehen. Ich habe hier auch einen CountDownLatch verwendet, um solange zu warten bis alle Threads fertig sind.
Java:
import java.awt.GridLayout;
import java.io.File;
import java.io.IOException;
import java.security.NoSuchAlgorithmException;
import java.util.concurrent.CountDownLatch;
import java.util.stream.Stream;
import javax.swing.JButton;
import javax.swing.JCheckBox;
import javax.swing.JFrame;
import javax.swing.JProgressBar;
import javax.swing.JTextField;
import javax.swing.SwingUtilities;
import javax.swing.WindowConstants;

public class T {
  static class UiGroup {
    String algorithm, hash = "";
    JButton button;
    JCheckBox checkbox;
    JProgressBar bar;
    JTextField field;
  }
  private static String[] algorithms = {"MD2", "MD5", "SHA_1", "SHA_256", "SHA_384", "SHA_512"};
  private static UiGroup[] uiGroups = new UiGroup[algorithms.length];
  private static File datei = new File("");

  static void createUI() {
    for(int i = 0; i < algorithms.length; i++) {
      uiGroups[i] = new UiGroup();
      uiGroups[i].algorithm = algorithms[i];
    }
    JFrame frame = new JFrame();
    frame.setDefaultCloseOperation(WindowConstants.EXIT_ON_CLOSE);
    frame.setLayout(new GridLayout(algorithms.length + 1, 4, 10, 10));
    for(UiGroup uiGroup: uiGroups) {
      uiGroup.button = new JButton(uiGroup.algorithm);
      uiGroup.field = new JTextField();
      uiGroup.bar = new JProgressBar();
      uiGroup.checkbox = new JCheckBox();
      frame.add(uiGroup.button);
      frame.add(uiGroup.field);
      frame.add(uiGroup.bar);
      frame.add(uiGroup.checkbox);
    }
    JButton startBtn = new JButton("start");
    startBtn.addActionListener(e -> start());
    frame.add(startBtn);
    frame.pack();
    frame.setVisible(true);
  }

  private static String createHash(String algorithm, File Datei) {
    try {
      Thread.sleep(2000);
    } catch(InterruptedException e) {}
      return "abc";
    /*
    try {
      switch(algorithm) {
        case "MD2": return Checksum_Utility.instance.createMD2(datei);
        case "MD5": return Checksum_Utility.instance.createMD5(datei);
        case ...
      }
    } catch (NoSuchAlgorithmException | IOException e) {
        e.printStackTrace();
    }
    */
  }

  private static void awaitLatch(CountDownLatch latch) {
    try {
      latch.await();
    } catch(InterruptedException e) {
      awaitLatch(latch);
    }
  }

  private static void start() {
    CountDownLatch latch = new CountDownLatch(uiGroups.length);
    for(UiGroup uiGroup: uiGroups) {
      uiGroup.button.setEnabled(false);
      uiGroup.checkbox.setEnabled(false);
      if (uiGroup.checkbox.isSelected()) {
        new Thread(() -> {
          String hash = createHash(uiGroup.algorithm, datei);
          SwingUtilities.invokeLater(() -> uiGroup.hash = hash);
          latch.countDown();
        }).start();
      } else {
        latch.countDown();
      }
    }
    new Thread(() -> {
      awaitLatch(latch);
      SwingUtilities.invokeLater(() -> {
        for(UiGroup uiGroup: uiGroups) {
          uiGroup.button.setEnabled(true);
          uiGroup.checkbox.setEnabled(true);
          uiGroup.field.setText(uiGroup.hash);
        }
      });
    }).start();
  }

  public static void main(String[] args) {
    createUI();
  }
}

Anstatt Threads manuell zu verwalten, kann man aber auch parallele Streams verwenden. In dem Fall würde die start Methode so aussehen.
Java:
private static void start() {
  for(UiGroup uiGroup: uiGroups) {
    uiGroup.button.setEnabled(false);
    uiGroup.checkbox.setEnabled(false);
  }
  new Thread(() -> {
    UiGroup[] result = Stream.of(uiGroups)
          .filter(uiGroup -> uiGroup.checkbox.isSelected())
          .parallel()
          .map(uiGroup -> {
            uiGroup.hash = createHash(uiGroup.algorithm, datei);
            return uiGroup;
          })
          .toArray(n -> new UiGroup[n]);
    SwingUtilities.invokeLater(() -> {
      for(UiGroup uiGroup: result) {
        uiGroup.button.setEnabled(true);
        uiGroup.checkbox.setEnabled(true);
        uiGroup.field.setText(uiGroup.hash);
      }
    });
  }).start();
}
 
B

Bungeefan

Gast
Ich habs jetzt mal so gelöst das ich alle "neuen" Threads wiederum in einen Thread packe, der dann auf die Threads mit dem Countdown wartet und dann die Buttons aktiviert. So wird die GUI nicht eingefroren aber es wird trotzdem gewartet.

Du kannst die ganzen graphischen Komponenten in Objekt bzw. Arrays stecken, um sie in einer Schleife abarbeiten zu können.
Das könnte dann z.B. so aussehen. Ich habe hier auch einen CountDownLatch verwendet, um solange zu warten bis alle Threads fertig sind.
Java:
import java.awt.GridLayout;
import java.io.File;
import java.io.IOException;
import java.security.NoSuchAlgorithmException;
import java.util.concurrent.CountDownLatch;
import java.util.stream.Stream;
import javax.swing.JButton;
import javax.swing.JCheckBox;
import javax.swing.JFrame;
import javax.swing.JProgressBar;
import javax.swing.JTextField;
import javax.swing.SwingUtilities;
import javax.swing.WindowConstants;

public class T {
  static class UiGroup {
    String algorithm, hash = "";
    JButton button;
    JCheckBox checkbox;
    JProgressBar bar;
    JTextField field;
  }
  private static String[] algorithms = {"MD2", "MD5", "SHA_1", "SHA_256", "SHA_384", "SHA_512"};
  private static UiGroup[] uiGroups = new UiGroup[algorithms.length];
  private static File datei = new File("");

  static void createUI() {
    for(int i = 0; i < algorithms.length; i++) {
      uiGroups[i] = new UiGroup();
      uiGroups[i].algorithm = algorithms[i];
    }
    JFrame frame = new JFrame();
    frame.setDefaultCloseOperation(WindowConstants.EXIT_ON_CLOSE);
    frame.setLayout(new GridLayout(algorithms.length + 1, 4, 10, 10));
    for(UiGroup uiGroup: uiGroups) {
      uiGroup.button = new JButton(uiGroup.algorithm);
      uiGroup.field = new JTextField();
      uiGroup.bar = new JProgressBar();
      uiGroup.checkbox = new JCheckBox();
      frame.add(uiGroup.button);
      frame.add(uiGroup.field);
      frame.add(uiGroup.bar);
      frame.add(uiGroup.checkbox);
    }
    JButton startBtn = new JButton("start");
    startBtn.addActionListener(e -> start());
    frame.add(startBtn);
    frame.pack();
    frame.setVisible(true);
  }

  private static String createHash(String algorithm, File Datei) {
    try {
      Thread.sleep(2000);
    } catch(InterruptedException e) {}
      return "abc";
    /*
    try {
      switch(algorithm) {
        case "MD2": return Checksum_Utility.instance.createMD2(datei);
        case "MD5": return Checksum_Utility.instance.createMD5(datei);
        case ...
      }
    } catch (NoSuchAlgorithmException | IOException e) {
        e.printStackTrace();
    }
    */
  }

  private static void awaitLatch(CountDownLatch latch) {
    try {
      latch.await();
    } catch(InterruptedException e) {
      awaitLatch(latch);
    }
  }

  private static void start() {
    CountDownLatch latch = new CountDownLatch(uiGroups.length);
    for(UiGroup uiGroup: uiGroups) {
      uiGroup.button.setEnabled(false);
      uiGroup.checkbox.setEnabled(false);
      if (uiGroup.checkbox.isSelected()) {
        new Thread(() -> {
          String hash = createHash(uiGroup.algorithm, datei);
          SwingUtilities.invokeLater(() -> uiGroup.hash = hash);
          latch.countDown();
        }).start();
      } else {
        latch.countDown();
      }
    }
    new Thread(() -> {
      awaitLatch(latch);
      SwingUtilities.invokeLater(() -> {
        for(UiGroup uiGroup: uiGroups) {
          uiGroup.button.setEnabled(true);
          uiGroup.checkbox.setEnabled(true);
          uiGroup.field.setText(uiGroup.hash);
        }
      });
    }).start();
  }

  public static void main(String[] args) {
    createUI();
  }
}

Anstatt Threads manuell zu verwalten, kann man aber auch parallele Streams verwenden. In dem Fall würde die start Methode so aussehen.
Java:
private static void start() {
  for(UiGroup uiGroup: uiGroups) {
    uiGroup.button.setEnabled(false);
    uiGroup.checkbox.setEnabled(false);
  }
  new Thread(() -> {
    UiGroup[] result = Stream.of(uiGroups)
          .filter(uiGroup -> uiGroup.checkbox.isSelected())
          .parallel()
          .map(uiGroup -> {
            uiGroup.hash = createHash(uiGroup.algorithm, datei);
            return uiGroup;
          })
          .toArray(n -> new UiGroup[n]);
    SwingUtilities.invokeLater(() -> {
      for(UiGroup uiGroup: result) {
        uiGroup.button.setEnabled(true);
        uiGroup.checkbox.setEnabled(true);
        uiGroup.field.setText(uiGroup.hash);
      }
    });
  }).start();
}

Das Problem ist nur ich habe pro Thread mehrere verschiedene Komponenten die abwechselnd angesteuert werden d.h. ich bräuchte mehrere Arrays. Werde ich vielleicht mal machen, trotzdem danke für das Beispiel und eure Hilfe.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
T Multithreading: Wie viele Threads sollte ich erstellen? Allgemeine Java-Themen 12
W Multithreading Alphabet Allgemeine Java-Themen 3
J Threads Multithreading Allgemeine Java-Themen 15
K Multithreading plattform übergreifend? Allgemeine Java-Themen 3
R Bruteforce hashes mit multithreading. Funktioniert das so? Allgemeine Java-Themen 0
K Multithreading: Service(Task), wait und continue Allgemeine Java-Themen 21
M JUnit & Multithreading - sehr seltener Fehler Allgemeine Java-Themen 3
C Ressourcensparendes Multithreading Allgemeine Java-Themen 3
A Multithreading mit JButtons Allgemeine Java-Themen 5
S Threads Multithreading- langsamer als Singlethreading-Programm Allgemeine Java-Themen 6
D Threads Multithreading Allgemeine Java-Themen 25
A MultiThreading.. Scheduling-Problem? Allgemeine Java-Themen 10
M Multithreading Problem Allgemeine Java-Themen 3
dayaftereh Multithreading Allgemeine Java-Themen 16
E Multithreading and volatile Allgemeine Java-Themen 10
J Wie die gleichzeitige Ausführung mehrerer Tasks trotz Multithreading verhindern? Allgemeine Java-Themen 2
G multithreading, concurrency conveyor belt beispiel Allgemeine Java-Themen 2
A Problem mit Zufallszahlen und Multithreading Allgemeine Java-Themen 14
I Problem mit Multithreading Allgemeine Java-Themen 4
H Singleton und MultiThreading [erledigt] Allgemeine Java-Themen 3
C Collection Multithreading? Allgemeine Java-Themen 33
O Multithreading mit Java 5 u den Concurrency APIs Allgemeine Java-Themen 7
O Multithreading und Multiprozessor Allgemeine Java-Themen 4
K Multithreading bei statischen Methoden Allgemeine Java-Themen 2
T ungewöhnliche Exception (Multithreading und JList) Allgemeine Java-Themen 10
K Frage zu ProgressBars, Algorithmen und Multithreading ->F Allgemeine Java-Themen 2
flashfactor Multithreading-Problem Allgemeine Java-Themen 4
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
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
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

Ähnliche Java Themen

Neue Themen


Oben