mehrere Threads: Methoden zentral unterbringen

javajoshi

Mitglied
Moin allerseits!

Habe (bei einem Test mit dem "Bogosort"-Sortierverfahren) eine Methode des Main-Threads nutzen lassen. Das Ergebnis war, dass es mit 8 Threads zwar die CPU auslastet, aber langsamer lief. Nutzen alle Threads eine eigene Methode, läuft es deutlich schneller.

Wie kann ich es realisieren, dass die Threads zwar eine eigene Methode besitzen, ich diese aber zentral stellen kann, d.h. nicht jede Klasse die gleiche Methode im Quelltext benötigt? Import? Include?

Vielen Dank schonmal
 

javajoshi

Mitglied
Nachtrag: Habe es mit Vererbung probiert, aber hier läuft der Algorithmus ebenfalls deutlich langsamer...
 
Zuletzt bearbeitet:

mrBrown

Super-Moderator
Mitarbeiter
Methoden „gehören“ keinem Thread.

Paralleles Laufen kann man nur mit Synchronisation vermeiden, dass musst du aber aktiv machen und passiert nicht einfach so.

Ohne zu wissen, was du da eigentlich gemacht hast, kann man nicht sagen was das Problem ist ;)
 

javajoshi

Mitglied
Da das Ganze so komplex ist, wollte ich Quelltext ersparen :) Hier der gekürzte Quelltext.

Der Hauptthread startet 8 Threads, die alle das Array zufällig durchwürfeln und prüfen, ob es zufällig sortiert ist :D
Wird ein Thread fertig, dann gibt er das Array aus, ändert er die Variable test.fertig auf true und alle Threads unterbrechen ihre Arbeit.
Java:
public class test {
static int z [];
static boolean fertig;
    public static void main (String args[]) throws InterruptedException
    Thread t1 = new Thread( new testp1(z) );
    Thread t2 = new Thread( new testp2(z) );
}

Ein Thread:
Java:
public class testp1 implements Runnable
{
  static int [] z1;
  public testp1 ( int [] start)
  {
      this.z1=Arrays.copyOfRange(start,0,start.length);;
  }
  @Override public void run()
  {
    do { shuffle(z1); test.c1++; }
    while ( (! sortiert(z1)) && (! test.fertig) );
  }
    //Shuffle (würfelt das Array durch)
    static int [] shuffle (int h [])
    {  }
    // prüft, ob es sortiert ist
    static boolean sortiert (int h [])
    {  }
}

Die beiden Methoden existieren in jeder Thread-Klasse testp1 bis testp8. So läuft Alles superschnell.

Packe ich allerdings die Methoden in die Hauptklasse test, so wird Alles sehr langsam:
  1. direkt aus den Threads mittels test.shuffle() aufrufen -> langsam
  2. Methoden an die Threads vererben lassen -> langsam
Ich hätte gern einen zentralen Ort, an dem der der Quelltext der Methode bearbeitbar ist und trotzdem jeweils zum Quelltext der Thread-Klasses gehört. Ich muss bei Änderungen immer mit copy'n'paste alles in die anderen Threads einfügen...
 
Zuletzt bearbeitet:

mrBrown

Super-Moderator
Mitarbeiter
Du brauchst nur eine einzige dieser Klassen, mehrere davon zu haben ist Unsinn.

Du darfst nur niemals static zum halten eines Zustandes nutzen ;) dann lösen sich alle deine Probleme in Luft auf
 

javajoshi

Mitglied
Du brauchst nur eine einzige dieser Klassen, mehrere davon zu haben ist Unsinn.
Das hatte ich in einem Beispiel so gesehen. Kann ich also für jeden Thread einfach
Java:
 Thread t1 = new Thread( new testp1(z) );
Thread t2 = new Thread( new testp1(z) );
Thread t3 = new Thread( new testp1(z) );
?

Du darfst nur niemals static zum halten eines Zustandes nutzen ;) dann lösen sich alle deine Probleme in Luft auf
Was meinst Du mit "halten eines Zustandes"? Warum ist das so?
 

mrBrown

Super-Moderator
Mitarbeiter
Das hatte ich in einem Beispiel so gesehen. Kann ich also für jeden Thread einfach
Ja.

Was meinst Du mit "halten eines Zustandes"? Warum ist das so?
Zustand meint alles, was zur Ausführung deines Programms gehört und irgendwie in Variablen liegt. In diesem Fall zB die Arrays, die Variable ob's fertig ist, ...

alles was static ist, gibt es zb nur genau ein einziges Mal in deinem Programm (das ist btw der Grund, warum es mit static und nur einer Klasse bei dir nicht klappte) und gehört nicht zu Objekten, sondern zu Klassen.
 

MoxxiManagarm

Top Contributor
Was meinst Du mit "halten eines Zustandes"? Warum ist das so?

Er meint damit Werte, welche sich verändern können, also eine Zustandsänderung haben können. Alle Instanzen des Objektes greifen auf diese eine Variable zu, sie ist nur einmal im Speicher. Wenn du static weglässt, dann ist sie für jede Instanz einmal im Speicher. Es kann also unter Umständen Speicher sparen. z.B. wenn du eine Verwaltung für Mitarbeiter hast könntest du allen den gleichen Arbeitgebernamen geben. Es birgt immer Gefahren mehrere Prozesse auf ein und dasselbe Objekt loszulassen - in diesem Fall dein Array.

Sortieren über Threads sollte m.E. nur über Teillisten gehen, also z.B. Thread1 sortiert die 1. Hälfte, Thread2 sortiert die 2. Hälfte etc. Anschließend mergen.
 

javajoshi

Mitglied
Super, ich danke euch. Läuft jetzt wunderbar das Ganze. Habe mich mal mit static, private usw befasst, das war mir gar nicht so richtig klar bisher.
Stupidsort kann ein Array mit 12 Integers jetzt 19.000.000 mal pro Sekunde zufällig mischen und so mit bspw. nur ~500.000.000 Versuchen die korrekte Sortierung finden. Super :D Da merkt man mal, wie schnell so ein Computer wirklich ist...

Sortieren über Threads sollte m.E. nur über Teillisten gehen, also z.B. Thread1 sortiert die 1. Hälfte, Thread2 sortiert die 2. Hälfte etc. Anschließend mergen.

Stupidsort bildet eine Ausnahme. Da das Array sowieso zufällig durchmischt wird, kann man das genau so gut von 8 Threads gleichzeitig machen lassen und schauen, wer als Erster fertig wird...
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
kilopack15 Mehrere Threads in einer Klasse Java Basics - Anfänger-Themen 8
N Mehrere Threads starten/stoppen Java Basics - Anfänger-Themen 4
M Mehrere Threads nutzen --> run() schneller als start(), Warum? Java Basics - Anfänger-Themen 3
F Collections ConcurrentModificationException in ArrayList, mehrere Threads Java Basics - Anfänger-Themen 7
isowiz Mehrere Threads schreiben in eine Datei Java Basics - Anfänger-Themen 5
V ObjectOutputStream/ObjectInputStream eines Objectes fuer mehrere Threads Java Basics - Anfänger-Themen 6
J Übergabe einer ArrayList an mehrere Threads Java Basics - Anfänger-Themen 3
N mehrere Threads erstellen Java Basics - Anfänger-Themen 2
G Herausfinden, wann mehrere Threads abgeschlossen sind Java Basics - Anfänger-Themen 3
V mehrere Threads starten + Endlosschleife Java Basics - Anfänger-Themen 3
T Mehrere Threads durch Pipes verbinden Java Basics - Anfänger-Themen 9
B auf mehrere Threads warten Java Basics - Anfänger-Themen 3
K Mehrere Werte in einem Switch Case parallel überprüfen Java Basics - Anfänger-Themen 23
S HashMap mehrere Keys zu einem Value Java Basics - Anfänger-Themen 3
T Mehrere if bedingungen ohne & Java Basics - Anfänger-Themen 2
I JPA Query für mehrere Klassen Java Basics - Anfänger-Themen 3
MiMa Java Doc mehrere Return Parameter Java Basics - Anfänger-Themen 11
javaBoon86 Array mehrere Dimensionen Java Basics - Anfänger-Themen 10
Buroto Klassen Mehrere .txt Datein verbienden und anschließend auslisten Java Basics - Anfänger-Themen 10
S mehrere TreeSets so speichern, dass man sie miteinander vergleichen kann Java Basics - Anfänger-Themen 1
P Zähler Variable für mehrere Objekte Java Basics - Anfänger-Themen 6
M Mehrere Daten/ Variablen Speichern Java Basics - Anfänger-Themen 9
C mehrere JPanel in ein JFrame bringen Java Basics - Anfänger-Themen 9
L Beim Java Programmstart, mehrere Parameter über die Kommandozeile übergeben Java Basics - Anfänger-Themen 9
D mehrere Berechnungen in einer Methode Java Basics - Anfänger-Themen 9
U Kann man bei Java gleich mehrere Bedingungen prüfen in der If, aber in einem "Satz"? Java Basics - Anfänger-Themen 1
Kotelettklopfer Mehrere Projekte in einem Git verwalten Java Basics - Anfänger-Themen 10
I JAX-RS Mehrere Parameter in Query Java Basics - Anfänger-Themen 3
M mehrere Rückgabenwerte aus Methode Java Basics - Anfänger-Themen 7
A Input/Output Mehrere Csv-Dateien einlesen Java Basics - Anfänger-Themen 2
R Mehrere Buchstaben aus einem String entfernen Java Basics - Anfänger-Themen 1
TimoN11 Java - Eine oder mehrere Eingaben möglich machen Java Basics - Anfänger-Themen 6
M Mehrere Datenbank zugriffe über tomee.xml regeln? Java Basics - Anfänger-Themen 1
S Mehrere Probleme im Code Java Basics - Anfänger-Themen 7
Ich lerne Java. Methoden Mehrere Methoden mit Punkt Java Basics - Anfänger-Themen 45
M Ausgabe einer Liste welche mehrere Stacks enthält Java Basics - Anfänger-Themen 3
D OOP- Eine Klasse in mehrere Klassen aufteilen Java Basics - Anfänger-Themen 7
F Mehrere Server Sockets in einer Anwendung Java Basics - Anfänger-Themen 9
T DoWhile Schleife über mehrere Mothoden Java Basics - Anfänger-Themen 5
B Methoden Mehrere ähnliche Methoden zusammenfassen Java Basics - Anfänger-Themen 24
E Mehrere Eingabezeilen gleichzeitig einlesen Java Basics - Anfänger-Themen 7
C Mehrere Zufallswerte Java Basics - Anfänger-Themen 4
M Dijkstra Algorithmus in Graphen auf mehrere verschiedene Knoten anwenden lassen Java Basics - Anfänger-Themen 11
R Error, wenn mehrere Clients gleichzeitig die Verbindung beenden Java Basics - Anfänger-Themen 16
F Mehrere Exceptions in einem Catch-Block abfangen Java Basics - Anfänger-Themen 12
O Datei in mehrere kleine Dateien umwandeln Java Basics - Anfänger-Themen 47
Henri Mehrere Ordner umbenennen Java Basics - Anfänger-Themen 11
E Mehrere Arrays addieren mit Übertrag Java Basics - Anfänger-Themen 13
B mehrere Werte mit scanner und while schleife einlesen, max berechnen bzw addieren Java Basics - Anfänger-Themen 2
J Mehrere paintComponenten in einem Programm Java Basics - Anfänger-Themen 0
F Mehrere Buttons mit einem ActionListener abdecken Java Basics - Anfänger-Themen 24
B Jeweils den Parent bekommen -> mehrere Ebenen Java Basics - Anfänger-Themen 2
M Erste Schritte Mehrere eingaben in einer Line vergleichen (if equals...) Java Basics - Anfänger-Themen 6
L Mehrere Jars im Unterordner Java Basics - Anfänger-Themen 2
L LibGDX - mehrere Screens Java Basics - Anfänger-Themen 1
J Sudoku mehrere Lösungen Java Basics - Anfänger-Themen 29
F Mehrere Instanzen der Klasse A EINER Instanz der Klasse B übergeben Java Basics - Anfänger-Themen 3
T Mehrere JFrames gleichzeitig öffnen Java Basics - Anfänger-Themen 6
O Erste Schritte Scanner mehrere male benutzen (Konsole) Java Basics - Anfänger-Themen 7
S mehrere If Bedingungen Java Basics - Anfänger-Themen 5
F Mehrere Zeilen zu einer Zeile zusammenfügen und in eine Datei schreiben Java Basics - Anfänger-Themen 1
B Mehrere Zahlen speichern Java Basics - Anfänger-Themen 60
M mehrere extends? Java Basics - Anfänger-Themen 19
N Datei Zeilenweise einlesen, Ausgabe mehrere Arrays Java Basics - Anfänger-Themen 7
C ButtonController löst mehrere Methoden aus Java Basics - Anfänger-Themen 5
D JPanel mehrere Formen zeichnen Java Basics - Anfänger-Themen 5
B Timer mehrere Male ausführen Java Basics - Anfänger-Themen 4
F mehrere eingegebene Zahlen mit Zahlen von 1-9 multiplizieren Java Basics - Anfänger-Themen 18
F Mehrere Konstruktoren? Wofür? Java Basics - Anfänger-Themen 21
J Mehrere Eingabefelder programmiert (Zeigt Fehler an) Java Basics - Anfänger-Themen 6
Jinnai4 Mehrere Textfelder überprüfen Java Basics - Anfänger-Themen 16
N Mehrere Forms auf einem Panel Java Basics - Anfänger-Themen 6
Tommy Nightmare Variable auf mehrere Ungleichheiten prüfen Java Basics - Anfänger-Themen 18
D Mehrere Objekte in ein Objekt zusammenfassen Java Basics - Anfänger-Themen 16
D Input/Output Mehrere Befehle nacheinander ausführen Java Basics - Anfänger-Themen 20
K Mehrere Objekte anlegen Java Basics - Anfänger-Themen 23
N Integers aus Textdatei auslesen und mehrere Arrays erstellen Java Basics - Anfänger-Themen 9
S Verständnis - Frage mehrere SQL Statements in While Schleife Java Basics - Anfänger-Themen 0
J MVC Pattern, mehrere Controller/Views/Models Java Basics - Anfänger-Themen 0
J Mehrere IF Anweisungen und dazugehörige ELSE Java Basics - Anfänger-Themen 6
I Klassen Mehrere Java Klassen in einer .java Datei Java Basics - Anfänger-Themen 7
V Mehrere Dateien aus JFileChooser in eine ArrayList speichern Java Basics - Anfänger-Themen 2
F Mehrere Konstruktoren Java Basics - Anfänger-Themen 10
A Mehrere Radiobuttons Java Basics - Anfänger-Themen 3
B Klassen Mehrere Objekte mit Schleife erstellen - How? Java Basics - Anfänger-Themen 1
T Mehrere Methoden in der main-Methode verknüpfen und aufeinander anwenden Java Basics - Anfänger-Themen 2
V OOP Aufnahme von Dreiecken in ein/mehrere Objekte Java Basics - Anfänger-Themen 0
Q OOP Mehrere Instanzen auf ein Feld Java Basics - Anfänger-Themen 13
C Klasse auf mehrere Objekte zugreifen lassen Java Basics - Anfänger-Themen 26
G Mehrere If-else-Sätze der Reihe nach durchlaufen lassen Java Basics - Anfänger-Themen 2
K Mehrere String.valueOf() kürzer schreiben / "packen"? Java Basics - Anfänger-Themen 2
F String mehrere male ausgeben? Java Basics - Anfänger-Themen 4
H wie mehrere variablen in einfacher for-schleife? Java Basics - Anfänger-Themen 2
H möglichkeiten für for-schleife? (mehrere ausgangsvariablen?) Java Basics - Anfänger-Themen 9
M PdfBox - mehrere Formularseiten Java Basics - Anfänger-Themen 2
Z Mehrere XML-Dateien zu einer zusammenfügen Java Basics - Anfänger-Themen 3
M GUI- mehrere Komponenten auf Container adden Java Basics - Anfänger-Themen 2
I Erste Schritte Resource Bundle - Alles in einem File oder mehrere? => Faktor Performance Java Basics - Anfänger-Themen 2
F Methoden split() - Mehrere Zeichen Java Basics - Anfänger-Themen 5
F Erste Schritte Mehrere nextInt() Eingaben nebeneinander ausgeben Java Basics - Anfänger-Themen 12

Ähnliche Java Themen

Neue Themen


Oben