Threads programmierung

Status
Nicht offen für weitere Antworten.
G

Gast

Gast
Moin,

ich habe untere Methode, welche manchmal nur einmal , manchmal aber auch 2 mal oder öfter nacheinander aufgerufen wird,
leider hab ich das Problem, wenn ich diese Methode öfter aufrufe, der Speicher ziemlich ansteigt und irgendwann das Programm mit Java Heap Space OutOfMemory abstürzt,
Ich habe jetzt keine Ahnung, wie so das manchmal funkt und dann so was auftritt,
Ich erzeuge unten ja Threads (je nachdem, wie oft ich die Methode aufrufe), welche mir die Arbeit verrichten sollen

Was mach ich da falsch,
Vielen Dank,


Code:
public void getListAndDrawOnTracePanel(final TracePanelLineAttributes tracePanelLineAttributes) {        
            Thread thread = new Thread() {
                @Override
                public void run() {
                    writeBean.setZeitstempel1(tracePanelLineAttributes.getFrom());
                    writeBean.setZeitstempel2(tracePanelLineAttributes.getUntil());
                    writeBean.setTabelle(tracePanelLineAttributes.getTableName());
                    List<DBWertReadBean> valueList = null;
                    try {
                        valueList = (List<DBWertReadBean>) AppSQLConfig.getSqlMapInstance().queryForList("getWerteVonProzetur", writeBean);                        
                        }
                    catch (SQLException ex) {
                        System.out.println("Ausnahme in der Klasse TracePanelListReader in der Methode run: " + ex);
                        }
                    tracePanelLineAttributes.getTracePanel().createDatasetAndYAxis("Name" + AStart.anzahlLines++, "Einheit", valueList, tracePanelLineAttributes.getColor());
                    if (tracePanelLineAttributes.isSetUpperAndLowerAxisBeforeZoom())
                        tracePanelLineAttributes.getTracePanel().setUpperAndLowerAxisBeforeZoom();
                    }
                };
            thread.start();            
        }
 

Murray

Top Contributor
In einer VM können nicht beliebig viele Threads gleichzeitig laufen. Wie sieht das denn in Deinem Fall auf? Kommt es vor, dass hier viele Threads schnell hintereinander gestartet werden (und zwar so schnell, dass sie schneller neu erzeugt werden, als sie verarbeitet werden können)?
 
G

Guest

Gast
So rufe ich die Methode oben auf, die Threads werden also schon ziemlich schnell erzeugt.
Kann ich da was dagegen machen?


Code:
for (int i = 0; i < tracePanel.getLineNumbers(); i++) {
                tracePanelLineAttributes = new TracePanelLineAttributes();
TracePanelLineAttributes tracePanelLineAttributes = createLineAttributes(tracePanel, from, new Timestamp(e.getSelectedDate().getTime().getTime()), tables[tableCounter++], getRandomColor(), true)
                tracePanelListReader.getListAndDrawOnTracePanel(tracePanelLineAttributes );
                }
 
G

Guest

Gast
PS: es handelt sich so um maximal 5- 7 Threads, welche über die for- Schleife erzeugt werden,
 

thisismyname

Mitglied
Gast hat gesagt.:
Moin,

ich habe untere Methode, welche manchmal nur einmal , manchmal aber auch 2 mal oder öfter nacheinander aufgerufen wird,
leider hab ich das Problem, wenn ich diese Methode öfter aufrufe, der Speicher ziemlich ansteigt und irgendwann das Programm mit Java Heap Space OutOfMemory abstürzt,
Ich habe jetzt keine Ahnung, wie so das manchmal funkt und dann so was auftritt,
Ich erzeuge unten ja Threads (je nachdem, wie oft ich die Methode aufrufe), welche mir die Arbeit verrichten sollen

Was mach ich da falsch,
Vielen Dank,


Code:
public void getListAndDrawOnTracePanel(final TracePanelLineAttributes tracePanelLineAttributes) {        
            Thread thread = new Thread() {
                @Override
                public void run() {
                    writeBean.setZeitstempel1(tracePanelLineAttributes.getFrom());
                    writeBean.setZeitstempel2(tracePanelLineAttributes.getUntil());
                    writeBean.setTabelle(tracePanelLineAttributes.getTableName());
                    List<DBWertReadBean> valueList = null;
                    try {
                        valueList = (List<DBWertReadBean>) AppSQLConfig.getSqlMapInstance().queryForList("getWerteVonProzetur", writeBean);                        
                        }
                    catch (SQLException ex) {
                        System.out.println("Ausnahme in der Klasse TracePanelListReader in der Methode run: " + ex);
                        }
                    tracePanelLineAttributes.getTracePanel().createDatasetAndYAxis("Name" + AStart.anzahlLines++, "Einheit", valueList, tracePanelLineAttributes.getColor());
                    if (tracePanelLineAttributes.isSetUpperAndLowerAxisBeforeZoom())
                        tracePanelLineAttributes.getTracePanel().setUpperAndLowerAxisBeforeZoom();
                    }
                };
            thread.start();            
        }

Probier doch mal das ganze in einer Richtigen Klassendefinition festzumachen und nicht so anonym... evtl liegts ja daran. Ich habs so noch nie probiert und kenn es nur mit Klassen die von Thread erben...

Code:
public void getListAndDrawOnTracePanel(final TracePanelLineAttributes tracePanelLineAttributes) {        
            Thread thread = new superKlasse();

            superKlasse.start();
         
public void superKlasse extends Thread{
                public void run() {
                    writeBean.setZeitstempel1(tracePanelLineAttributes.getFrom());
                    writeBean.setZeitstempel2(tracePanelLineAttributes.getUntil());
                    writeBean.setTabelle(tracePanelLineAttributes.getTableName());
                    List<DBWertReadBean> valueList = null;
                    try {
                        valueList = (List<DBWertReadBean>) AppSQLConfig.getSqlMapInstance().queryForList("getWerteVonProzetur", writeBean);                        
                        }
                    catch (SQLException ex) {
                        System.out.println("Ausnahme in der Klasse TracePanelListReader in der Methode run: " + ex);
                        }
                    tracePanelLineAttributes.getTracePanel().createDatasetAndYAxis("Name" + AStart.anzahlLines++, "Einheit", valueList, tracePanelLineAttributes.getColor());
                    if (tracePanelLineAttributes.isSetUpperAndLowerAxisBeforeZoom())
                        tracePanelLineAttributes.getTracePanel().setUpperAndLowerAxisBeforeZoom();
                    }
                }
   }
        }

Nur so als POC, weis nicht genau ob das jetzt schon genauso passt.

greetz
 

Murray

Top Contributor
Anonymous hat gesagt.:
PS: es handelt sich so um maximal 5- 7 Threads, welche über die for- Schleife erzeugt werden,
Das sollte normalerweise noch passen.

Hantieren die Thread mit sehr großen Ergebnissen für die einzelnen Queries? Dann ist der Heap vielleicht wirklich einfach zu klein eingestellt. In dem Fall könntest Du der Java-VM per -Xmx-Option mehr Heap gönnen. Wenn es allerdings doch irgendwo ein Memory-Leak gibt, dann wird der Fehler immer noch auftreten - nur eben später.
 

Murray

Top Contributor
mahe hat gesagt.:
Wo liegt denn da die Grenze?
In einem Bereich wo man sich darum sorgen muss oder irgendwo in den Sternen?

Das ist schwer zu sagen. Ein limitierender Faktor ist der Stack, der für jeden einzelnen Stack reserviert werden muss. Diesen Wert man per -Xss festlegen, aber eben nur für alle Thread gleichzeitig. Wenn man also - z.B. wegen hoher Rekursiontiefen - irgendwo einen großen Stack braucht, dann passen insgesamt weniger Threads in den Speicher.

Ausprobieren kann man das mit einem kleinen Testprogramm:
Code:
public class ThreadTest {
	
	
	public static void main( String[] args) throws Exception {
		
		final Object o = new Object();
		int num = 0;
		while ( true) {
			num++;
			new Thread( new Runnable() {
				public void run() {
					 synchronized( o) {
					 	try {
					 		o.wait();
					 	} catch ( Exception e) {
					 		e.printStackTrace();
					 	}
					 }
				}
			}).start();
			System.out.println( num + ". Thread gestartet"); System.out.flush();
		}
			
	}
}
Mit den Default-Einstellungen werden bei mir über 5000 Threads gestartet, bevor es knallt. Sorge ich per -Xss10M für einen größeren Stack, so knallt es bei knapp 200. Interessanterweise scheint auch das Erhöhen des maximalen Heaps per -Xmx die maximale Thread-Anzahl zu verringern.

Allerdings stellt sich natürlich die Frage, was heutige Rechner überhaupt mit Dutzenden von Threads anfangen sollen - selbst mit mehreren Kernen und Hyperthreading ist die Anzahl der effektiv parallel zu verarbeitenden Tasks üblicherweise deutlich kleiner.

Insofern könnte man vielleicht sagen: sofern man nicht die Stackgröße auf enorme Werte setzen muss, braucht man derzeit keine Sorgen zu haben, dass man weniger Threads anlegen kann, als der Rechner parallel zu verarbeiten in der Lage ist. Verwendet man aber das Thread-Konzept da, wo man eigentlich eine Event-Queue bräuchte (wenn man also z.B. für jedes GUI-Event einen neuen Thread startet, um den Event-Dispatcher-Thread zu entlasten), dann könnte man durchaus vor die Wand laufen.
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
6 Java - Threads - parallele Programmierung - Tutorial 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
K Zeitkritische Threads Allgemeine Java-Themen 14
K Threads - Swing - Synchronisation nötig? Allgemeine Java-Themen 8

Ähnliche Java Themen

Neue Themen


Oben