Executors.newCachedThreadPool() nicht verstanden

dmike

Bekanntes Mitglied
Hi,

wenn ich einen
Java:
ExecutorService pool = Executors.newCachedThreadPool()
anlege

und dann pool.execute(new WorkerThread()); sage was passiert dann?


1a) Wird nur eine Instanz des WorkerThread() gestartet?
1b) Oder muss ich um rei WorkerThreads im Pool zu besitzen, drei Mal hintereinander pool.execute(new WorkerThread()) aufrufen?

2) Oder werden beliebig viele WorkerThreads gestartet, wie viele entscheidet der Pool.



Eine andere Frage in dem Zusammenhang:

Eine Klasse "PoolManager", die einen Thread startet bzw. einen Pool wie oben gesagt, hat eine start() Methode. Damit soll der Pool gestartet werden. Damit der Pool auch lange genug laufen kann, hab ich in die start() Methode eine Schleife eingebaut. Wenn ich die Klasse starte (mit JUnit), dann geht die CPU Load sofort auf 100% .

Java:
   /**
     * 
     */
    public void startPool() {
    	try {
    		
    		pool.execute(new WorkerThread());
    		pool.execute(new WorkerThread());
[B]
        	for(;;) {
            	
        	}[/B]
    	} catch (Exception e) {
    		shutdown();
    		throw new RuntimeException(e);
    	}
    }


WorkerThread() selbst ist eine Inner-Class des PoolManagers. Die WorkerThreads pollen eine LinkedBlockingQueue . Die Queue ist leer als was kann die 100% Load machen?


Java:
  private class WorkerThread implements Runnable {
    	private volatile boolean shouldRun = true;

    	WorkerThread() {
    		log.debug("creating worker.");
    	}

        public void run() {
            while (shouldRun) {
                try {
                    MessageTask task = poll(5, MILLISECONDS);
                    
                    if (task == null ) 
                    	continue;
                    
                    task.executeTask();
                    
                    System.out.println("executed");
                
                } catch (Exception e) {
                    shouldRun = false;
                	throw new RuntimeException(e);
                }
            }
        }
    }
 

ThreadPool

Bekanntes Mitglied
Hi,

wenn ich einen
Java:
ExecutorService pool = Executors.newCachedThreadPool()
anlege

und dann pool.execute(new WorkerThread()); sage was passiert dann?

Dann wird dem Threadpool ein Thread hinzugefügt der dein "Runnable" sprich deinen WorkerThread ausführt. Um drei Jobs [1] zu starten musst du tatsächlich drei mal pool.execute() aufrufen. Der Pool selbst entscheidet, bis auf die Wiedeverwendung eines Threads für den Job, nichts weiter. Des Weiteren kannst dem CachedThreadPool solange Aufgaben übergeben bis dein Speicher platzt. Und diese 100% Auslastung hast du sicher der Endlosschleife zu verdanken.


[1] Du solltest WorkerThread umbenennen da es nicht wirklich ein Thread ist sondern viel mehr ein "Job" der von einem Thread ausgeführt wird. Die Benennung verwirrt sonst, vorallem wenn man später mal wirklich die Klasse Thread erweitert.
 
Zuletzt bearbeitet:

dmike

Bekanntes Mitglied
(Das steht in der Doku zu newCachedThreadPool eigentlich drin...?!)

Die andere Frage... morgen vielleicht

Dort steht z.B.

"Creates a thread pool that creates new threads as needed...."

Frage: as needed by whom? Applikation oder Threadpool?

Das kann man interpretieren wie man will.

[1] Du solltest WorkerThread umbenennen da es nicht wirklich ein Thread ist, sondern viel mehr ein "Job" der von einem Thread ausgeführt wird. Die Benennung verwirrt sonst, vorallem wenn man später mal wirklich die Klasse Thread erweitert.

Danke für die Erklärung und den Hinweis. Für mich macht ein Runnable nur als Teil eines Threads Sinn, aber hast recht, technisch gesehen ist der Name nicht sauber. Werd ich ändern.

Das mit der Last, da komme ich immer noch nicht hinter. Dass ein Thread/Runnable Leerlauf hat ist doch gerade Sinne der Aktion. Ich hab den Code soweit, dass beim execute() Aufruf von MessageTask wirklich etwas passiert trotzdem ist da noch genug Leerlauf... und 100% Last

Während der Thread fleißig pollt wartet der Rest des Programms per

Java:
selector.select( 20 * 1000 );

auf irgendeine Event

Die Endlosschleife in JUnit habe ich durch ein Thread.sleep(60*1000) ersetzt.
 
Zuletzt bearbeitet:

ThreadPool

Bekanntes Mitglied
Dort steht z.B.

"Creates a thread pool that creates new threads as needed...."

Frage: as needed by whom? Applikation oder Threadpool?

Das kann man interpretieren wie man will.

Naja, "wie man will" ist übertrieben. Der Threadpool stellt einen Service für seine Verwender bereit nämlich die Jobs die ihm übergeben werden in Threads zu packen und auszuführen. Er erstellt also so viele Threads wie nötig sind um die ganzen Jobs auszuführen die ihm übergeben werden.

Und zum Rest, dann liegt es vermutlich an dem "polling" welches du innerhalb eines Runnables betreibst, das Runnable wird zwar für höchstens 5 ms suspended während des poll() am Queue aber wenn es mehrere solcher Jobs gibt und die alle ständig die while-Schleife durchackern wird die Auslastung dementsprechend hoch sein.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
hieuhp132 Server wird nicht auf zweiten Anfrage von Client geupdated Netzwerkprogrammierung 3
JavaDevOp Socket Status von UDP-Port prüfen (PortUnreachableException funktioniert nicht?) Netzwerkprogrammierung 32
A Bei FTP Übertragung wird Datei nicht komplett übertragen Netzwerkprogrammierung 2
B Multicast-Nachrichten-Empfang funktioniert nicht Netzwerkprogrammierung 5
M JAX-WS unter Java 17 plötzlich nicht mehr möglich Netzwerkprogrammierung 5
S BufferedStream funktioniert nicht immer Netzwerkprogrammierung 7
T OutputStream kommt nicht an Netzwerkprogrammierung 18
G UDP Packet empfangen funktioniert nicht. Netzwerkprogrammierung 16
L30nS RMI RMI-Server kann Dialog nicht volkommen anzeigen Netzwerkprogrammierung 2
L Server-Socket liest Input-Stream nicht Netzwerkprogrammierung 5
Tobero Java serversocket nicht nur zuganglich für localhost Netzwerkprogrammierung 6
T String von Client zu Server kommt nicht an Netzwerkprogrammierung 92
S .jar läuft local, aber nicht remote (SSH/Terminal) Netzwerkprogrammierung 10
Z Kann nicht Daten vom Server lesen Socket Netzwerkprogrammierung 10
J SSL haut nicht hin Netzwerkprogrammierung 3
A Socket-Anwendung (BufferedWriter/Reader liest nicht aktuellen Wert) Netzwerkprogrammierung 6
platofan23 Socket Java Socket mit DynDns nicht erreichbar Netzwerkprogrammierung 6
J Wechsel auf Jdk13 , sfpt funktionier nicht mehr Netzwerkprogrammierung 2
Dann07 Proxy funktioniert nicht so wie gewünscht! Netzwerkprogrammierung 18
B RESTful API weiß nicht weiter Netzwerkprogrammierung 2
L Kann VM nicht ueber Host Name finden Netzwerkprogrammierung 0
V Ich finde den Fehler nicht... Netzwerkprogrammierung 2
H Einfacher Server funktioniert nicht Netzwerkprogrammierung 1
T HTTPS-Requests an Server: POST-Parameter kommen nicht an Netzwerkprogrammierung 5
S Socket Webserver mit SSLSocket geht nicht Netzwerkprogrammierung 1
P RMI stub wird nicht gefunden Netzwerkprogrammierung 8
N Test Servlet funktioniert nicht Netzwerkprogrammierung 11
M com.google.gson wird nicht erkannt Netzwerkprogrammierung 2
M Socket Server antwortet dem Client nicht Netzwerkprogrammierung 6
J FTP Upload über Proxy funktioniert nicht Netzwerkprogrammierung 1
C Mini Client-Server-Anwendung funktioniert nicht Netzwerkprogrammierung 8
D FTP ListNames() funktinoniert nicht richtig Netzwerkprogrammierung 2
Thallius JDBC getConnection kommt nicht zurück Netzwerkprogrammierung 1
KingSquizzi3 Website parsen mit Hilfe von jsoup funktioniert nicht Netzwerkprogrammierung 3
J Java Server empfängt php inhalt nicht Netzwerkprogrammierung 1
V TCP Client funktioniert auf Emulator aber nicht auf Smartphone Netzwerkprogrammierung 5
P RMI - Neue eigene Instanz für jeden Aufruf auf nicht serialisierbares Objekt - wie? Netzwerkprogrammierung 0
F FTP FTPClient Datei lässt sich nicht öffnen Netzwerkprogrammierung 4
F Reader/ Writer werden nicht geschlossen Netzwerkprogrammierung 2
Z Verbindung zwischen 2 Rechnern über ServerSockets nicht möglich Netzwerkprogrammierung 3
F Java Server Scanner oder InputStream kann nicht gelsesen werden! Netzwerkprogrammierung 6
R Socket bei server.accept(); gehts nicht weiter Netzwerkprogrammierung 2
K Server liest Daten nicht Netzwerkprogrammierung 6
N RMI "RMI über Lan funktioniert nicht" & "RMI-Server im Lan scannen" Netzwerkprogrammierung 13
G Mail senden funktioniert nicht mit SSL Netzwerkprogrammierung 7
L IText mit Servlets, funktioniert nicht Netzwerkprogrammierung 0
E Gruppenchat: Über HTTPS oder nicht? Netzwerkprogrammierung 5
P nanoHttp upload.html page lädt nicht Netzwerkprogrammierung 4
M Byte Array kommt nicht an Netzwerkprogrammierung 0
X Daten können nicht sofort empfangen werden Netzwerkprogrammierung 1
D TCP Socket funktioniert nicht richtig Netzwerkprogrammierung 3
K ByteArray über Netzwerk senden klappt nicht Netzwerkprogrammierung 5
D Socket UDP Client reagiert nicht auf spontane Meldungen Netzwerkprogrammierung 5
C Servlet erstellen klappt nicht Netzwerkprogrammierung 3
A Socket Socket-Problem - Object wird nicht übertragen Netzwerkprogrammierung 3
S Socket (client) verbindet nicht Netzwerkprogrammierung 6
B Methoden und Konstruktoren von Java.net package werden nicht geladen Netzwerkprogrammierung 2
L Email versenden mit Java funktioniert nicht, Fehlermeldungen: MessagingException & SocketException Netzwerkprogrammierung 10
L Server anpingen (Pingzeit) ?? Pingzeit wird nicht verändert Netzwerkprogrammierung 6
C Portscanner funktioniert nicht! Netzwerkprogrammierung 8
M JSP wird im gesamten Projekt nicht neugeladen Netzwerkprogrammierung 3
B HTTP Webseite unter IP-Addresse nicht aufrufbar - unter Domain schon Netzwerkprogrammierung 9
K Chatprogramm - Server funktioniert nicht Netzwerkprogrammierung 5
A Socket ASCii Zeichen werden nicht per udp übermittelt. please help . Netzwerkprogrammierung 6
J Erster Server-Client läuft auf lokalem Rechner problemlos. Zwei Rechner über das Internet nicht Netzwerkprogrammierung 8
H HTTP Header Response kann nicht ausgelesen werden Netzwerkprogrammierung 4
K Socket InputStream wird nicht erzeugt Netzwerkprogrammierung 4
G FTP FTP-Client funktioniert nicht bei Modem-Verbindungen Netzwerkprogrammierung 8
R Socket SSL-Connect in Servlet - keystore wird nicht gefunden Netzwerkprogrammierung 2
D JNLP über Webstart funktioniert nicht... Netzwerkprogrammierung 2
V Socket Objekte werden nicht aktualisiert Netzwerkprogrammierung 2
F Kann Klasse nicht zu Servlet casten Netzwerkprogrammierung 5
T Server und Client verbinden nicht Netzwerkprogrammierung 6
M HTTP File Upload mit Prozessbar Funktioniert nicht. Netzwerkprogrammierung 8
K Socket byte Schleife beendet nicht Netzwerkprogrammierung 9
J FTP FTP funktioniert nicht. Netzwerkprogrammierung 5
M Socket Exception tritt auf - weiß nicht weiter Netzwerkprogrammierung 3
L Socket Client empfängt nicht Netzwerkprogrammierung 6
S anderer Rechner wird nicht gefunden Netzwerkprogrammierung 20
das-mo Client/Server sendet nicht Netzwerkprogrammierung 7
M Socket InputStream liest nicht vollständig Netzwerkprogrammierung 7
S soap kann nicht zu 127.0.0.1:8090 unter Windows verbinden Netzwerkprogrammierung 2
F RMI einfacher Chat - Callbacks(?) funktionieren nicht Netzwerkprogrammierung 7
X Änderung des Objekts wird nicht serialisiert Netzwerkprogrammierung 9
M Socket TCP keep alive Exception wird nicht ausgelöst Netzwerkprogrammierung 11
T Empfangen klappt Senden nicht - Connection timed out Netzwerkprogrammierung 12
G Client funktioniert nicht Netzwerkprogrammierung 2
C HTTP Content-Length nicht übermittelt!? Netzwerkprogrammierung 7
J Socket Chatserver aus dem Internet nicht erreichbar Netzwerkprogrammierung 19
S UDP Broadcast - Pakete kommen nicht immer an Netzwerkprogrammierung 15
D RMI URL nicht gefunden Netzwerkprogrammierung 2
M Senden von Daten nicht direkt möglich? Netzwerkprogrammierung 6
N Socket geht auf Windows, aber auf Mac nicht ? Netzwerkprogrammierung 3
Z Socket Connection reset by peer nur per IP nicht über localhost Netzwerkprogrammierung 13
M while-Schleife funktioniert nicht bei Nachrichtempfang von Server Netzwerkprogrammierung 3
P Socket IRC Client nicht kompatibel mit Server Netzwerkprogrammierung 30
L Socket Chat funktioniert nicht Netzwerkprogrammierung 2
S Servlet - Datei kann nicht gelöscht werden Netzwerkprogrammierung 12
K RMI Angemeldetes Objekt nicht aktuell? Netzwerkprogrammierung 9
2 Socket ObjectOutputstream kehrt nicht zurück Netzwerkprogrammierung 2

Ähnliche Java Themen

Neue Themen


Oben