Torna indietro   Hardware Upgrade Forum > Software > Programmazione

6G, da rete che trasporta dati a rete intelligente: Qualcomm accelera al MWC 2026
6G, da rete che trasporta dati a rete intelligente: Qualcomm accelera al MWC 2026
Al MWC Qualcomm annuncia una coalizione industriale per lanciare il 6G entro il 2029 e introduce agenti IA per la gestione autonoma della RAN. Ericsson, presente sul palco, conferma la direzione: le reti del futuro saranno IA-native fin dalla progettazione
CHUWI CoreBook Air alla prova: design premium, buona autonomia e qualche compromesso
CHUWI CoreBook Air alla prova: design premium, buona autonomia e qualche compromesso
CHUWI CoreBook Air è un ultraleggero da 1 kg con Ryzen 5 6600H, display 14" 16:10 e 16 GB LPDDR5. Offre buona portabilità, autonomia discreta e costruzione in alluminio, ma storage PCIe 3.0 e RAM saldata limitano l'espandibilità. A 549 euro sfida brand più noti nella stessa fascia di mercato.
Roborock Saros 20: il robot preciso e molto sottile
Roborock Saros 20: il robot preciso e molto sottile
Il nuovo robot di Roborock per l'aspirazione della polvere e il lavaggio dei pavimenti spicca per immediatezza d'uso e per l'efficacia dell'azione, grazie anche a un ridotto sviluppo in altezza. Saros 20 integra un motore da ben 36.000Pa di potenza e un sistema di lavaggio a due panni rotanti, con bracci estensibili e un sistema di navigazione molto preciso.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 02-02-2016, 20:35   #1
Scanca
Junior Member
 
Iscritto dal: May 2013
Messaggi: 12
[C] Implementazione Terminazione Gentile con SIGINT e SIGTERM

Ciao a tutti,

nel mio programma multithread devo implementare un algoritmo di terminazione gentile alla ricezione dei segnali SIGINT e SIGTERM.
Come deve essere implementato il gestore? dove devo mettere le join dei thread?
Io uso una variabile globale per terminare i cicli infiniti dei thread tramite il gestore di segnale e vorrei che il main finisse l'esecuzione ripulendo l'ambiente (chiusura socket, chiusura file temporanei, free,ecc...)
Solo che non capisco come fare di preciso la gestione dei segnali

Ultima modifica di Scanca : 02-02-2016 alle 20:42.
Scanca è offline   Rispondi citando il messaggio o parte di esso
Old 02-02-2016, 20:48   #2
WarDuck
Senior Member
 
L'Avatar di WarDuck
 
Iscritto dal: May 2001
Messaggi: 12955
Il segnale può essere gestito o in maniera asincrona, quindi con il gestore del segnale che viene invocato quando viene ricevuto uno, oppure sincrona, aspettando ad esempio nel main un segnale (bloccandoti).

Nel primo caso, ovvero il caso asincrono, devi tenere in considerazione che può arrivare in qualsiasi momento.

Puoi vedere il gestore del segnale come se fosse un altro thread, di durata breve.

Lì puoi ad esempio modificare una variabile globale booleana (flag) e, se non hai bisogno di una segnalazione immediata, aspettare che chi è in loop su quella variabile se ne accorga.

ATTENZIONE: proprio perché il gestore si comporta come un altro thread devi assicurarti che il compilatore non ottimizzi il loop credendo che la variabile assumi sempre il valore "true".

Puoi fare questo dichiarando la variabile come "volatile": in tal caso verrà effettuato sempre l'accesso in memoria e questo ti mette al riparto da eventuali modifiche "sotto al naso".
WarDuck è offline   Rispondi citando il messaggio o parte di esso
Old 02-02-2016, 20:59   #3
Scanca
Junior Member
 
Iscritto dal: May 2013
Messaggi: 12
Quindi, se non ho capito male devo chiamare le join sia nel main che nel gestore giusto? O in uno di questi due posti?
Io uso già una variabile appuno volatile chiamata run che è a 0 e che metto a 1 nel gestore del SIGINT.
Dopo che ho fatto questo cosa devo fare nel gestore?
Scanca è offline   Rispondi citando il messaggio o parte di esso
Old 03-02-2016, 22:52   #4
fano
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2095
All'inizio del main scrivi:

Codice:
void die (int signal)
{
       // segnaliamo in qualche modo ai thread che devono uscire

       for (i = 0; i < n_threads; i++)
            pthread_join();

       exit(signal);
}


int main(void)
{
      signal(SEGFAULT, die);
      signal(SIGPIPE, die);
      signal(SIGxxx, die); 

      [...]
      die(0);
}
I miei programmi di solito non terminano mai con exit(), ma appunto con die() che quindi ha la doppia funzione di uscita fatale e uscita con successo... sempre il clean up debbo fare.

Detto questo in C l'interazione tra thread e segnali è un po' complessa per esempio anche se la logica dice che il sighandler dovrebbe essere eseguita dal main thread questo non è garantito potrebbe eseguirlo un thread a caso o quello che è andato in core!

Una possibilità per fare clean up nei thread che sono i "proprietari" delle risorse è usare il costrutto pthread_cleanup_push() / pthread_cleanup_pop(): http://man7.org/linux/man-pages/man3...up_push.3.html

Insomma auguri !
__________________
Cosmos C# Open Source Managed Operating System
Cosmos Thread Ufficiale
Cosmos Official Site Vuoi collaborare allo sviluppo? Unisciti alla chat!
fano è offline   Rispondi citando il messaggio o parte di esso
Old 04-02-2016, 13:21   #5
WarDuck
Senior Member
 
L'Avatar di WarDuck
 
Iscritto dal: May 2001
Messaggi: 12955
Quote:
Originariamente inviato da Scanca Guarda i messaggi
Quindi, se non ho capito male devo chiamare le join sia nel main che nel gestore giusto? O in uno di questi due posti?
Io uso già una variabile appuno volatile chiamata run che è a 0 e che metto a 1 nel gestore del SIGINT.
Dopo che ho fatto questo cosa devo fare nel gestore?
Non vedo a cosa serve la JOIN nel signal handler.

Al massimo è il main che si pone in JOIN dei suoi thread figli.

Il gestore del segnale può anche solo impostare un flag e terminare.

PS: signal è deprecato, dovresti usare sigaction.
WarDuck è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


6G, da rete che trasporta dati a rete intelligente: Qualcomm accelera al MWC 2026 6G, da rete che trasporta dati a rete intelligen...
CHUWI CoreBook Air alla prova: design premium, buona autonomia e qualche compromesso CHUWI CoreBook Air alla prova: design premium, b...
Roborock Saros 20: il robot preciso e molto sottile Roborock Saros 20: il robot preciso e molto sott...
ASUS ROG Kithara: quando HIFIMAN incontra il gaming con driver planari da 100mm ASUS ROG Kithara: quando HIFIMAN incontra il gam...
Roborock Qrevo Curv 2 Flow: ora lava con un rullo Roborock Qrevo Curv 2 Flow: ora lava con un rull...
MaiaSpace ha posticipato il suo primo la...
Roscosmos ha annunciato il ripristino de...
Monarch: se usi più di due scherm...
Microsoft espande la sua offerta di clou...
Traffico di licenze Windows e Office: ar...
'Sembra stia defecando': il creatore di ...
Akamai: zero trust su tecnologia NVIDIA ...
Apple presenta il MacBook Air con chip M...
Memorie e chip cinesi nel mirino degli U...
Apple presenta il MacBook Pro con M5 Pro...
Apple rinnova la linea monitor: arrivano...
M5 Pro e M5 Max ufficiali: i chip Apple ...
World of Warcraft: Midnight è adesso dis...
NVIDIA: i nuovi driver limitano le tensi...
La tua azienda è conforme all'AI ...
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: 20:18.


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