Threads und Nebenläufigkeit

Status
Nicht offen für weitere Antworten.

micbur

Bekanntes Mitglied
Hallo,

ich will verschiedene Threads erzeugen, die gleichzeitig laufen können und sich ggf auch Daten schicken.

Also aus C kenne ich fork(). fork() kehrt nicht mehr zum Elternprozess zurück, sodass ein Elternprozess sich derweilen auch schonmal um etwas anderes kümmern kann, während der Kindsprozess sich irgendwelchem Käse hingibt. hier wartet der Kindsprozess einige Zeit (vorerst).

Irgendwie klappt das aber in Java nicht so recht.
Ich erzeuge zwar je einen neuen Thread mit 'new Thread', aber erst, wenn der Thread fertig ist, werden die nächsten zeilen im Programmablauf abgearbeitet.

habe ich was falsch gemach oder geht das in Java gar nicht?

Ciao micbur
 

L-ectron-X

Gesperrter Benutzer
Zu jedem Thread "gehört" eine run()-Methode, die überschrieben werden muss. Die Methode enthält den Code, den der Thread zu seiner Laufzeit ausführen soll. Threads werden mit start() gestartet. Nur eine Instanz von Thread erzeugen reicht da nicht.
 

Thanni

Bekanntes Mitglied
selbst wenn man einen paralell laufenden thread hat ist das doch kein process oder ?

ich würde sagen das wenn das programm beendet wird auch alle threads beendet werden und nicht wie bei einem kindprocess weiterlaufen oder irre ich mich da ?

ok das mit dem beenden war nicht die frage aber ich würde schon gerne wissen ob man einen kindprocess erzeugen kann in java

gruß thanni

[edit] vielleicht mit static? [/edit]
 

Grizzly

Top Contributor
@Thanni: Nein, static hat damit nichts zu tun.

Java unterstützt - soviel ich weiss - nur Threads. Einen Kind-Prozess kann man nur erzeugen, in dem man ein neues Programm mit bspw. exec(String[] cmdarray) (Klasse Runtime) startet.

Wenn Du in Java einen Thread Dir basteln willst, geht das in etwa so:
Ersteinmal bastelst Du eine Klasse, die nachher arbeiten soll:
Code:
public class Worker implements Runnable {
	/**
	 * Dies ist der Standard Konstruktor.
	 */
	public Worker() {
		super();
	}
	
	/**
	 * Diese Methode führt die Arbeit aus.
	 * Siehe auch {@link http://java.sun.com/j2se/1.4.2/docs/api/java/lang/Runnable.html}.
	 */
	public void run() {
		// Pruefen, ob Thread beendet werden soll.
		while (!Thread.interrupted()) {
			System.out.println('A');
			try {
				// 1 Sekunde warten.
				Thread.sleep(1000);
			} catch (InterruptedException ie) {
				// Wenn der Thread waehrend des Wartens den Befehl zum Beenden erhaelt.
			}
		}
	}
}
Und schließlich die Hauptklasse:
Code:
public class ThreadStarter {

	public static void main(String[] args) {
		Worker worker;
		Thread thread;
		
		// Arbeiter anlegen.
		worker = new Worker();
		// Thread anlegen (und gleich benennen)
		thread = new Thread(worker, "Arbeiter");
		// Thread starten
		thread.start();
		try {
			// 10 Sekunden warten...
			Thread.sleep(10000);
		} catch (InterruptedException ie) {
		}
		// Thread beenden.
		thread.interrupt();
	}
}
Kommunizieren können die Threads entweder über ein gemeinsamen Objekt, Sockets oder einen PipedStream. Beim gemeinsamen Objekt musst Du daran denken, den Zugriff zu synchronisieren.
Zum Thema Socket:
Zum Thema PipedStreams:
 

micbur

Bekanntes Mitglied
Hallo Grizzly,

danke für die umfassende Antwort.
Ich hatte das so gemacht, dass ich mir eine Klasse zum Starten schaffte (Main) und dann eine Klasse (MyThread extends Thread). Thread implementiert schon Runnable und eine run()-Methode ist auch schon da, allerdings wartet mein Main immer erst auf einen Thread, bis er zum thread2.start() kommt.

Das ist irgendwie verwirrend. Ist Nebenläufigkeit also mit Java nicht drin? Oder besser gesagt, nicht mit Threads!

Ciao micbur
 
R

Roar

Gast
doch, natürlich *lol*.
du wirst wohl irgendwas falsch gemacht haben. zeig mal deinen code.
 

micbur

Bekanntes Mitglied
Ich präsentiere...
Code:
public class Main {

	public static void main(String[] args) {
        
        System.out.println(" --- System is running ... generating processes ... ");
        
        ThreadGroup info4 = new ThreadGroup("Group");
        InfoThread t1 = new InfoThread(info4, "T1");
        InfoThread t2 = new InfoThread(info4, "T2");
        InfoThread t3 = new InfoThread(info4, "T3");
        InfoThread t4 = new InfoThread(info4, "T4");
        InfoThread t5 = new InfoThread(info4, "T5");
        InfoThread t6 = new InfoThread(info4, "T6");
        
        try {
            t1.start();
            t1.join();
            t3.start();
            t2.start();
            t2.join();
            t5.start();
            t3.join();
            t4.start();
            t5.join();
            t6.start();
            t6.join();
        }
        catch (Exception e) {
            System.err.println(e);
        }
        
        System.out.println(" --- System is shutting down ...");
	}
}

und dann noch ...
Code:
public class InfoThread extends Thread {
    
    
    public InfoThread(ThreadGroup group, String name) {
        this.setName(name);
    }
    
    public void run() {
        System.out.print(" +++ "+this.getName()+" ");
        Thread[] arr = new Thread[100];
        
        int numberOfThreads = enumerate(arr);
//        System.out.println(numberOfThreads+"|"+arr.length);
        
        System.out.print("(");
        for (int i = 0; i < numberOfThreads; i++) {
            if (arr[i].isAlive()) {
                System.out.print(arr[i].getName()+",");
            }
        }
        System.out.print(")\r\n");
        
        try {
            
            sleep(1000);
            
        }
        catch (Exception e) {
            System.err.println(e);
        }
        
        System.out.print(" --- "+this.getName()+" ");
        System.out.print("(");
        for (int i = 0; i < numberOfThreads; i++) {
            if (arr[i].isAlive()) {
                System.out.print(arr[i].getName()+",");
            }
        }
        System.out.print(")\r\n");
    }
}

Ciao micbur
 
B

Beni

Gast
join wartet bis der Thread abgeschaltet wurde...

Also versuch es einfach mit einer anderen Reihenfolge!

Code:
        try {
            t1.start();
            t3.start();
            t2.start();
            t5.start();
            t4.start();
            t6.start();

            t1.join();
            t2.join();
            t3.join();
            t4.join();
            t5.join();
            t6.join();
        }
        catch (Exception e) {
            System.err.println(e);
        }

mfg Beni
 
G

Guest

Gast
Hmmm, eine Reihenfolge hat wenig damit zu tun, denke ich.

OK, nehmen wir an, ich erzeuge 6 (wirklich) nebenläufige Prozesse, die eine Sekunde warten, und sich dann beenden, dann dauert der gesamte Programmabluaf eine Sekunde, weil jeder Prozess für sich eine Sekunde wartet.

Jedoch dauert der gesamte Programmablauf bei mir 6 Sekunden, es werden also alle Prozesse sequenziell angestoßen und durchlaufen. Das ist aber nicht nebenläufig.

Oder sehe ich das falsch?

Ciao micbur
 
B

Beni

Gast
Dann pass mal auf:

Variante 1:
Code:
public class Main{
    public static void main( String[] args ){
        ThreadTest a = new ThreadTest( "A" );
        ThreadTest b = new ThreadTest( "B" );
        ThreadTest c = new ThreadTest( "C" );
        ThreadTest d = new ThreadTest( "D" );
        ThreadTest e = new ThreadTest( "E" );
        
        long begin = System.currentTimeMillis();
        
        try {
            a.start();
            b.start();
            c.start();
            d.start();
            e.start();
            
            a.join();
            b.join();
            c.join();
            d.join();
            e.join();
        } catch (InterruptedException e1) {
            e1.printStackTrace();
        }
        
        long end = System.currentTimeMillis();
        
        System.out.println();
        System.out.println( "Laufzeit: " + (end - begin) / 1000 + "s" );
    }
}

class ThreadTest extends Thread{
    private String name;
    
    public ThreadTest( String name ){
        this.name = name;
    }
    
    public void run(){
        for( int i = 0; i < 5; i++ ){
            System.out.println( name + ": " + i );
            
            try {
                Thread.sleep( 1500 );
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }
    }
}

Ausgabe:
A: 0
B: 0
C: 0
D: 0
E: 0
A: 1
B: 1
D: 1
C: 1
E: 1
A: 2
B: 2
D: 2
C: 2
E: 2
A: 3
B: 3
C: 3
D: 3
E: 3
A: 4
B: 4
C: 4
D: 4
E: 4

Laufzeit: 7s


Variante 2:
Code:
public class Main{
    public static void main( String[] args ){
        ThreadTest a = new ThreadTest( "A" );
        ThreadTest b = new ThreadTest( "B" );
        ThreadTest c = new ThreadTest( "C" );
        ThreadTest d = new ThreadTest( "D" );
        ThreadTest e = new ThreadTest( "E" );
        
        long begin = System.currentTimeMillis();
        
        try {
            a.start();
            a.join();
            
            b.start();
            b.join();
            
            c.start();
            c.join();
            
            d.start();
            d.join();
            
            e.start();
            e.join();
        } catch (InterruptedException e1) {
            e1.printStackTrace();
        }
        
        long end = System.currentTimeMillis();
        
        System.out.println();
        System.out.println( "Laufzeit: " + (end - begin) / 1000 + "s" );
    }
}

class ThreadTest extends Thread{
    private String name;
    
    public ThreadTest( String name ){
        this.name = name;
    }
    
    public void run(){
        for( int i = 0; i < 5; i++ ){
            System.out.println( name + ": " + i );
            

            try {
                Thread.sleep( 1500 );
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }
    }
}

Ausgabe:
A: 0
A: 1
A: 2
A: 3
A: 4
B: 0
B: 1
B: 2
B: 3
B: 4
C: 0
C: 1
C: 2
C: 3
C: 4
D: 0
D: 1
D: 2
D: 3
D: 4
E: 0
E: 1
E: 2
E: 3
E: 4

Laufzeit: 37s



Achte auch auf die Reihenfolge der Ausgabe... Die Laufzeit...

Beweisführung abgeschlossen. :wink:

mfg Beni
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
B Ausgabe auf der Konsole bei Nebenläufigkeit, Threads und Synchronisation Allgemeine Java-Themen 8
B Nebenläufigkeit, Threads und Synchronisation Allgemeine Java-Themen 10
F Threads - Nebenläufigkeit Allgemeine Java-Themen 6
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

Ähnliche Java Themen

Neue Themen


Oben