Torna indietro   Hardware Upgrade Forum > Software > Programmazione

DLSS 4.5: con Dynamic Frame Generation e MFG 6X NVIDIA alza la posta
DLSS 4.5: con Dynamic Frame Generation e MFG 6X NVIDIA alza la posta
DLSS 4.5 introduce Dynamic Multi Frame Generation e MFG 6X, permettendo fino a cinque frame generati per ogni frame renderizzato. I test su Cyberpunk 2077 e 007 First Light mostrano forti incrementi di FPS e riduzione della latenza su RTX 5090 Laptop. Migliorano fluidità, stabilità e qualità visiva.
Plaud NotePin S, il registratore IA si fa indossabile (ma è facile da perdere)
Plaud NotePin S, il registratore IA si fa indossabile (ma è facile da perdere)
Quattro modi di indossarlo, stessa app del Plaud Note Pro e integrazione con il desktop. Il registratore IA da indossare di Plaud eccelle in mobilità, ma resta vincolato all'abbonamento ed è facile da perdere
Redmi Watch 6 in prova: lo smartwatch con ampio display da 2000 nit a meno di 100 euro
Redmi Watch 6 in prova: lo smartwatch con ampio display da 2000 nit a meno di 100 euro
Xiaomi ha portato Redmi Watch 6 anche sul mercato italiano, puntando su un display AMOLED da 2,07 pollici con picco di luminosità a 2000 nit, frame in alluminio da 9,9mm e un'autonomia dichiarata di 12 giorni. Lo smartwatch gira su HyperOS 3 e integra GPS, Bluetooth 5.4 e oltre 150 sport mode. Il tutto a meno di 100 euro
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 22-06-2007, 13:24   #1
tomminno
Senior Member
 
Iscritto dal: Oct 2005
Messaggi: 3306
Terminare correttamente un thread

Qual è il modo corretto per terminare dall'esterno un thread?
La struttura del thread è del tipo

Codice:
while(!stop)
{
    //Fai qualcosa
    Sleep(30000);
}
Poichè il thread è sempre in stato di sleep e devo deallocare la classe che ha creato il thread capita (se non aspetto l'uscita per la condizione di stop) che questo possa risvegliarsi dopo che ho deletato la classe causando ovviamente casini.

Inoltre sempre in generale quando è il caso di eseguire la CloseHandle su un thread?
tomminno è offline   Rispondi citando il messaggio o parte di esso
Old 22-06-2007, 14:06   #2
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Messaggi: 5206
Quote:
Originariamente inviato da tomminno Guarda i messaggi
Qual è il modo corretto per terminare dall'esterno un thread?
La struttura del thread è del tipo

Codice:
while(!stop)
{
    //Fai qualcosa
    Sleep(30000);
}
Si sta parlando di API Win32, è bene precisarlo.

Comunque la cosa migliore è che il thread termini in modo "naturale", cioè che la funzione principale del thread termini o che venga eseguita prima una ExitThread().
L'ideale è appunto usare una variabile, nel tuo caso 'stop' da settare a TRUE per far terminare il ciclo.
Il problema principale è che per la Sleep hai messo un tempo bello lungo (30 sec.), quindi ammesso di essere appena entrato nella Sleep, se si setta stop a TRUE, c'è da attendere 30 secondi!

Una soluzione migliore è usare WaitForSingleObject. Crei un evento con CreateEvent e poi, nel tuo thread, usi WaitForSingleObject per fare il wait su quell'evento, specificando sempre i millisecondi di timeout che ti servono.
Se qualcuno dall'esterno fa diventare l'evento "signaled", la WaitForSingleObject ritorna immediatamente e te ne accorgi perché restituisce WAIT_OBJECT_0 invece di WAIT_TIMEOUT (in caso di timeout).

Quote:
Originariamente inviato da tomminno Guarda i messaggi
Inoltre sempre in generale quando è il caso di eseguire la CloseHandle su un thread?
La documentazione dice: The thread object remains in the system until the thread has terminated and all handles to it have been closed through a call to CloseHandle.

Quindi quando il thread è terminato e non hai più bisogno di quel handle.
__________________
Andrea, Senior Java developerSCJP 5 (91%) • SCWCD 5 (94%)
Java Versions Cheat Sheet

Ultima modifica di andbin : 22-06-2007 alle 14:09.
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 22-06-2007, 15:46   #3
tomminno
Senior Member
 
Iscritto dal: Oct 2005
Messaggi: 3306
Quote:
Originariamente inviato da andbin Guarda i messaggi
Si sta parlando di API Win32, è bene precisarlo.

Comunque la cosa migliore è che il thread termini in modo "naturale", cioè che la funzione principale del thread termini o che venga eseguita prima una ExitThread().
L'ideale è appunto usare una variabile, nel tuo caso 'stop' da settare a TRUE per far terminare il ciclo.
Infatti generalmente faccio così, finchè non mi è capitato di dover fare un thread che si deve risvegliare solo sporadicamente.

Quote:
Il problema principale è che per la Sleep hai messo un tempo bello lungo (30 sec.), quindi ammesso di essere appena entrato nella Sleep, se si setta stop a TRUE, c'è da attendere 30 secondi!

Una soluzione migliore è usare WaitForSingleObject. Crei un evento con CreateEvent e poi, nel tuo thread, usi WaitForSingleObject per fare il wait su quell'evento, specificando sempre i millisecondi di timeout che ti servono.
Se qualcuno dall'esterno fa diventare l'evento "signaled", la WaitForSingleObject ritorna immediatamente e te ne accorgi perché restituisce WAIT_OBJECT_0 invece di WAIT_TIMEOUT (in caso di timeout).
Grazie proverò.
Conosci l'equivalente su Linux? Basta un semplice pthread_cancel?

Quote:
La documentazione dice: The thread object remains in the system until the thread has terminated and all handles to it have been closed through a call to CloseHandle.

Quindi quando il thread è terminato e non hai più bisogno di quel handle.
Ma sarebbe lecito chiamare la CloseHandle prima dell'uscita dalla funzione di callback?

Ultima modifica di tomminno : 22-06-2007 alle 15:51.
tomminno è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


DLSS 4.5: con Dynamic Frame Generation e MFG 6X NVIDIA alza la posta DLSS 4.5: con Dynamic Frame Generation e MFG 6X ...
Plaud NotePin S, il registratore IA si fa indossabile (ma è facile da perdere) Plaud NotePin S, il registratore IA si fa indoss...
Redmi Watch 6 in prova: lo smartwatch con ampio display da 2000 nit a meno di 100 euro Redmi Watch 6 in prova: lo smartwatch con ampio ...
Mad Catz M.M.O. 7+: lo stesso DNA del R.A.T. 8+ ADV, ma con molti più pulsanti Mad Catz M.M.O. 7+: lo stesso DNA del R.A.T. 8+ ...
Radeon RX 9070 GRE, AMD la porta in tutto il mondo | Recensione Gigabyte Gaming OC Radeon RX 9070 GRE, AMD la porta in tutto il mon...
TIM, rincari da luglio: come evitare l'a...
WWDC 26: Il Digital Markets Act dell'Uni...
WWDC 26: Apple Intelligence rivoluziona ...
Siri AI arriva alla WWDC 2026: nuove cap...
Alla WWDC 2026 arriva la nuova architett...
Tra schede madri, schede video e IA le n...
Nintendo, multa da 35 milioni di euro in...
L'amministrazione Trump valuta una parte...
WWDC 26: Apple rinnova il controllo pare...
Apple al WWDC 26 presenta iOS 27: Liquid...
Xbox, alla fine, dà ragione a Pla...
Minecraft Dungeons 2: Microsoft ha annun...
Synology al Computex 2026: nuova generaz...
Quobly raccoglie 115 milioni di euro per...
BYD batte sul tempo Tesla Roadster: avvi...
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:13.


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