Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Google Pixel 10 è compatto e ha uno zoom 5x a 899€: basta per essere un best-buy?
Google Pixel 10 è compatto e ha uno zoom 5x a 899€: basta per essere un best-buy?
Google Pixel 10 è uno smartphone che unisce una fotocamera molto più versatile rispetto al passato grazie allo zoom ottico 5x, il supporto magnetico Pixelsnap e il nuovo chip Tensor G5. Il dispositivo porta Android 16 e funzionalità AI avanzate come Camera Coach, mantenendo il design caratteristico della serie Pixel con miglioramenti nelle prestazioni e nell'autonomia. In Italia, però, mancano diverse feature peculiari basate sull'AI.
Prova GeForce NOW upgrade Blackwell: il cloud gaming cambia per sempre
Prova GeForce NOW upgrade Blackwell: il cloud gaming cambia per sempre
L'abbonamento Ultimate di GeForce NOW ora comprende la nuova architettura Blackwell RTX con GPU RTX 5080 che garantisce prestazioni tre volte superiori alla precedente generazione. Non si tratta solo di velocità, ma di un'esperienza di gioco migliorata con nuove tecnologie di streaming e un catalogo giochi raddoppiato grazie alla funzione Install-to-Play
Ecovacs Deebot X11 Omnicyclone: niente più sacchetto per lo sporco
Ecovacs Deebot X11 Omnicyclone: niente più sacchetto per lo sporco
Deebot X11 Omnicyclone implementa tutte le ultime tecnologie Ecovacs per l'aspirazione dei pavimenti di casa e il loro lavaggio, con una novità: nella base di ricarica non c'è più il sacchetto di raccolta dello sporco, sostituito da un aspirapolvere ciclonico che accumula tutto in un contenitore rigido
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 21-03-2010, 11:24   #1
PuNkEtTaRo
Senior Member
 
L'Avatar di PuNkEtTaRo
 
Iscritto dal: Jan 2005
Città: Roma
Messaggi: 1541
[JAVA]Monitorare i thread lanciati da una servlet

Ciao a tutti ragazzi,
sto scrivendo una servlet che, ad ogni chiamata del metodo doGet, lancia un thread più o meno in questo modo:
Codice:
String host = request.getParameter("host");
int depth = Integer.parseInt(request.getParameter("depth"));
long lapse = Long.parseLong(request.getParameter("lapse"));

new Thread(new Traverse(host, depth, lapse)).start();
Il thread in questione entrerà in un loop dove farà periodicamente quello che deve fare.
Il mio problema ora è come stoppare i singoli thread che verranno lanciati e come monitorarli ovvero, io voglio sapere in ogni momento quanti e quali sono i thread running (lanciati dal doGet ovviamente) ed avere la possibilità di fermarli.
Qualcuno ha qualche idea?

Grazie in anticipo
__________________
[ punkeroso ] - [ powered by Arch Linux ]
PuNkEtTaRo è offline   Rispondi citando il messaggio o parte di esso
Old 21-03-2010, 12:25   #2
nuovoUtente86
Senior Member
 
Iscritto dal: Mar 2007
Messaggi: 7863
Ti basta tenerne riferimento in una struttura dati. Quanto all' interrompibilità, dipende da cosa c'è scritto nel metodo run, ovvero se hai previsto la verifica periodica di un flag di interruzione.
nuovoUtente86 è offline   Rispondi citando il messaggio o parte di esso
Old 21-03-2010, 12:40   #3
PuNkEtTaRo
Senior Member
 
L'Avatar di PuNkEtTaRo
 
Iscritto dal: Jan 2005
Città: Roma
Messaggi: 1541
Quote:
Originariamente inviato da nuovoUtente86 Guarda i messaggi
Ti basta tenerne riferimento in una struttura dati. Quanto all' interrompibilità, dipende da cosa c'è scritto nel metodo run, ovvero se hai previsto la verifica periodica di un flag di interruzione.
Ed in che modo ne tengo il riferimento? Dovrei chiamare ogni thread in un modo diverso...
Nel metodo run avevo previsto un flag che settato su false interrompesse il while in modo da terminare il thread.
Il mio problema è semplicemente come tener traccia di tutti i thread avviati. Magari se potessi farmi un esempio mi saresti di grande aiuto. Per quanto riguarda la struttura dati non ci sono problemi.
Grazie

Ciao
__________________
[ punkeroso ] - [ powered by Arch Linux ]
PuNkEtTaRo è offline   Rispondi citando il messaggio o parte di esso
Old 21-03-2010, 12:59   #4
nuovoUtente86
Senior Member
 
Iscritto dal: Mar 2007
Messaggi: 7863
Codice:
QualsiasiStrutturaDati listaThread= new QualsiasiStrutturaDati();
per ogni thread lanciato
listaThread.add (new Thread(....));
nuovoUtente86 è offline   Rispondi citando il messaggio o parte di esso
Old 22-03-2010, 09:50   #5
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
Se hai in ballo questioni di scalabilità prova a dare un'occhiata al package java.util.concurrent

Vedendo ogni singola Traverse come un task da eseguire, puoi appoggiarti ad un Executor a cui passare ogni nuovo task creato per l'esecuzione.
In pratica passeresti dallo scrivere:
Codice:
(new Thread(t)).start();
// dove 't' è un Traverse "travestito" da Runnable.
a:
Codice:
e.execute(r);
// dove 'e' è un Executor.
Traverse, il tuo task, diventa l'implementazione di un Runnable (se Traverse non ritorna niente ne lancia eccezioni che ti interessa catturare; altrimenti l'alternativa è Callable) da passare all'Executor per l'esecuzione.

Volendo c'è anche l'interfaccia ExecutorService (la specifica implementazione dell'ExecutorService che si sceglie definisce le politiche di creazione e gestione dei thread per l'esecuzione dei task) che, dato il task da mandare in esecuzione, restituisce l'oggetto Future che ne rappresenta il futuro risultato (cosa che ti permette di gestirne lo stato, ad esempio richiedere la cancellazione dell'esecuzione del task):
Codice:
Future<?> t = es.submit(r);
// dove 'es' è l'ExecutorService scelto, e 't' è il Future per il task 'r' passato in ingresso.
Tutto questo ovviamente aumenta la quantità & complessità del tuo codice, per cui il gioco vale la candela solo se i task da mandare in esecuzione possono anche essere tanti, per cui l'ExecutoService può diventare utile per questioni di scalabilità.

Puoi cominciare a leggere qualcosa qui.
__________________

As long as you are basically literate in programming, you should be able to express any logical relationship you understand.
If you don’t understand a logical relationship, you can use the attempt to program it as a means to learn about it.
(Chris Crawford)

Ultima modifica di banryu79 : 22-03-2010 alle 10:13.
banryu79 è offline   Rispondi citando il messaggio o parte di esso
Old 22-03-2010, 10:46   #6
PuNkEtTaRo
Senior Member
 
L'Avatar di PuNkEtTaRo
 
Iscritto dal: Jan 2005
Città: Roma
Messaggi: 1541
Quote:
Originariamente inviato da banryu79 Guarda i messaggi
Se hai in ballo questioni di scalabilità prova a dare un'occhiata al package java.util.concurrent

Vedendo ogni singola Traverse come un task da eseguire, puoi appoggiarti ad un Executor a cui passare ogni nuovo task creato per l'esecuzione.
CUT
Sei stato veramente gentile ed esauriente, appena torno a casa mi fiondo a documentarmi sugli Executor!
Grazie

Ciao
__________________
[ punkeroso ] - [ powered by Arch Linux ]
PuNkEtTaRo è offline   Rispondi citando il messaggio o parte di esso
Old 22-03-2010, 11:09   #7
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
Quote:
Originariamente inviato da PuNkEtTaRo Guarda i messaggi
appena torno a casa mi fiondo a documentarmi sugli Executor!
Ti posto qualche risorsa online che potresti trovare interessante da esaminare:

- Ovviamente il capitolo dedicato al multithreading presente nel compendio "The Really Big Index" dei Java Tutorial;
- I javadoc (informazioni sparse sulle varie classi e interfacce) del package java.util.concurrent; (in particolare: Callable, Future, RunnableFuture, FutureTask, Executor, ExecutorService, ThreadFactory, ThreadPoolExecutor, Executors);
- Questo tutorial [2004] della IBM (è neccessario registrarsi per accedere ai tutorial);
- Questo tutorial, estratto dal testo "Java - How to program" edito dalla Deitel (che però non ho letto).
__________________

As long as you are basically literate in programming, you should be able to express any logical relationship you understand.
If you don’t understand a logical relationship, you can use the attempt to program it as a means to learn about it.
(Chris Crawford)
banryu79 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Google Pixel 10 è compatto e ha uno zoom 5x a 899€: basta per essere un best-buy? Google Pixel 10 è compatto e ha uno zoom ...
Prova GeForce NOW upgrade Blackwell: il cloud gaming cambia per sempre Prova GeForce NOW upgrade Blackwell: il cloud ga...
Ecovacs Deebot X11 Omnicyclone: niente più sacchetto per lo sporco Ecovacs Deebot X11 Omnicyclone: niente più...
Narwal Flow: con il mocio orizzontale lava i pavimenti al meglio Narwal Flow: con il mocio orizzontale lava i pav...
Panasonic 55Z95BEG cala gli assi: pannello Tandem e audio senza compromessi Panasonic 55Z95BEG cala gli assi: pannello Tande...
Iliad: si consolida la partnership tecno...
Il SoC a 2 nm di Samsung non sfigura nel...
Prezzo shock per i Galaxy Buds FE + nuov...
Il nuovo SoC di Qualcomm vuole stupire: ...
Offerta lampo per pulire l'auto: aspirap...
I robotaxi di Amazon entrano in azione: ...
ECOVACS DEEBOT T50 PRO OMNI Gen2 domina ...
iPhone 17 Pro su Amazon: tutti i colori,...
Disney Plus da 2,99 euro al mese per 3 m...
Nuovo test di accensione dei motori per ...
Novità dalle analisi dell'asteroi...
La PS6 sarà più potente del previsto: ec...
Sony svela Xperia 10 VII: è il nu...
Amazon Weekend da urlo: iPhone 16 a prez...
Spotify diffida ReVanced: chiesta la rim...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 22:28.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
Served by www3v