Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora
Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora
WF-1000X M6 è la sesta generazione di auricolare in-ear sviluppata da Sony, un prodotto che punta a coniugare facilità di utilizzo con una elevata qualità di riproduzione dei contenuti audio e una cura nella riduzione del rumore ambientale che sia da riferimento
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI
Snowflake ha presentato diverse novità per la sua piattaforma legate all'intelligenza artificiale. Quella forse più eclatante è una collaborazione con OpenAI, ma non mancano diverse nuove funzionalità che rendono la piattaforma più flessibile e in grado di rispondere meglio alle esigenze in continuo cambiamento delle aziende
Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI
Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI
Con velocità teoriche fino a 11 Gbps, gestione tramite app intelligente e protezione avanzata dei dispositivi, Roamii BE Pro porta il Wi‑Fi 7 tri‑band nelle abitazioni più esigenti. Un sistema Wi-Fi Mesh proposto da MSI allo scopo di garantire agli utenti una rete fluida e continua capace di sostenere streaming 8K, gaming competitivo e le applicazioni moderne più esigenti in termini di banda
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 23-07-2006, 22:13   #1
LimiT-MaTz
Senior Member
 
Iscritto dal: Apr 2003
Città: Genova
Messaggi: 673
Errore handling dei segnali

Ho un problema per quanto riguarda l'handling dei segnali.
Sto sviluppando una piccola applicazione (mi serve fondamentalmente per esercizio).
ho intenzione di fare un handler per il segnale SIGTSTP.
fondamentalmente vorrei ottenere questo in caso di ctrl+z l'applicazione deve morire e prima di morire deve liberare un struttura dati.

la struttura dati e' una semplice lista doppiolinkata definita nella lib standard.
il tutto viene istanziato nel main
Codice:
list<process> * List_proc = new list<process>();
essendo instaziata nel main quando vado a "costruire la funzione richiamata dall'handle dei signal" non posso fare accesso in alcun modo alla struttura (non posso passarla per parametro).
Una soluzione potrebbe essere quella di dichiarare List_proc globale cio' risolverebbe i miei problemi. Non voglio seguire questa via ma provare un'altra via.

L'idea e' questa:
fare un handle banale che chiami exit(OK) e andare a definire la funzione da chiamare all'uscita:

Codice:
-- Function: int on_exit (void (*FUNCTION)(int STATUS, void *ARG),void *ARG)
ho quindi creato una funzione "Delete_list" che si occupi di chiamare il delete in caso il puntatore *ARG esista.
Codice:
void Delete_list(int n,void  *lst)
{
	if(lst)
	{
		cout<<"DELETE"<<endl;
		delete (list<process> *) lst;
	}
}
e l'ho registrata nel main:
Codice:
	on_exit(Delete_list,List_proc);			/* Operation to do at exit   */
ora ho provato un po il programma e gira senza errore, al segnale ctrl-z si chiude senza dare errori.
Per verificare se la heap viene liberata veramente ho fatto un test con valgrind e mi sono accorto che cio' non accade
Codice:
==28163== 
==28163== ERROR SUMMARY: 0 errors from 0 contexts (suppressed: 19 from 1)
==28163== malloc/free: in use at exit: 5,795 bytes in 143 blocks.
==28163== malloc/free: 1,152 allocs, 1,009 frees, 1,888,613 bytes allocated.
==28163== For counts of detected errors, rerun with: -v
==28163== searching for pointers to 143 not-freed blocks.
==28163== checked 116,208 bytes.
==28163== 
==28163== LEAK SUMMARY:
==28163==    definitely lost: 0 bytes in 0 blocks.
==28163==      possibly lost: 1,527 bytes in 71 blocks.
==28163==    still reachable: 4,268 bytes in 72 blocks.
==28163==         suppressed: 0 bytes in 0 blocks.
==28163== Reachable blocks (those to which a pointer was found) are not shown.
il problema avviene solo esclusivamente quando chiamo exit(OK) ovvero quando "premo ctrl-z".

sapreste aiutarmi?
Grazie.
__________________
MaTz!
LimiT-MaTz è offline   Rispondi citando il messaggio o parte di esso
Old 23-07-2006, 23:19   #2
LimiT-MaTz
Senior Member
 
Iscritto dal: Apr 2003
Città: Genova
Messaggi: 673
poiche' registravo la funzione on_exit prima che l'oggetto list venisse istanziato il puntatore void *lst rimaneva null quindi non entrava mai nell'if in cui faccio il delete.
Codice:
	List_proc = new list<process>();	
	
	on_exit(Delete_list,List_proc);							/* Operation to do at exit   */
cosi' facendo ho risolto.

vi sembra una buona soluzione?
__________________
MaTz!
LimiT-MaTz è offline   Rispondi citando il messaggio o parte di esso
Old 24-07-2006, 09:07   #3
trallallero
Senior Member
 
L'Avatar di trallallero
 
Iscritto dal: May 2006
Città: Wursteland
Messaggi: 1749
Quote:
Originariamente inviato da LimiT-MaTz
...
vi sembra una buona soluzione?
NO!

é ottima
ma "valgrind" cos'é ? e che s.o. usi ?

Comunque apprezzo chi si sforza di trovare alternative al semplice "dichiaro globale e mi tolgo il pensiero"
qui a volte mi trovo dei pro*C da modificare con (non esagero) 100/150 righe di variabili globali
Peró non capisco la tua funzione legata al segnale ... io ho sempre usato
questo tipo
Codice:
void Function( int , siginfo_t *, void * )
tu invece
Codice:
int on_exit (void (*FUNCTION)(int STATUS, void *ARG),void *ARG)
o forse ho capito male io ? usi la struct sigaction ?
__________________
Nintendo WIII 4d Turbo Intercooler - Sestium X 666 99,312 GHz - 6.984 Ram Σ(9999) MHz - HDD SATA 97e^(10) bytes 93³ rpm - ATI biberon X900z Mb - Win Eight SP (1 > yours) 16 Valve
trallallero è offline   Rispondi citando il messaggio o parte di esso
Old 24-07-2006, 09:35   #4
LimiT-MaTz
Senior Member
 
Iscritto dal: Apr 2003
Città: Genova
Messaggi: 673
Il S.O. e' gnu/linux
per quanto riguarda valgrind ti rimando qui: http://valgrind.org/

Hai perfettamente ragione mi sono espresso male la funzione
Codice:
int on_exit (void (*FUNCTION)(int STATUS, void *ARG),void *ARG)
non centra nulla con il segnale, ti posto una breve descrizione:
Codice:
NAME
       on_exit - register a function to be called at normal process termination

SYNOPSIS
       #include <stdlib.h>

       int on_exit(void (*function)(int , void *), void *arg);

DESCRIPTION
       The on_exit() function registers the given function to be called at nor-
       mal process termination, whether via exit(3) or via return from the pro-
       gram's main().  The function is passed the argument to exit(3)  and  the
       arg argument from on_exit().
per quanto riguarda l'handler del segnale uso questa funzione per registrarlo:
Codice:
void signal_handler_exit(int n)
{
	exit(0);
}

	signal(SIGINT,  signal_handler_exit);		/* Signal handler for ctrl-c */
ora mi si pone un altro problema, io vorrei anche gestire SIGWINCH, signal che viene mandata ad ogni resize del terminale.
handler in questione dovrebbe richiamare un funzione get_terminal_size(int *row,int *col) => questa funzione fa una ioctl e aggiorna i valori di row e col.
in modo che potro' usarli per formattare il testo correttamente.
Anche qui vorrei fare a meno di variabili globali il problema e' che non posso passare alal funzione signal una funzione void get_terminal_size(int *row,int *col) ma sono costretto ad una void function(int n).

Grazie ancora
p.s: non ditemi di usare ncurses :P
__________________
MaTz!
LimiT-MaTz è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora Sony WF-1000X M6: le cuffie in-ear di riferiment...
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI Snowflake porta l'IA dove sono i dati, anche gra...
Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo M...
Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi Recensione HUAWEI Mate X7: un foldable ottimo, m...
Nioh 3: souls-like punitivo e Action RPG Nioh 3: souls-like punitivo e Action RPG
Le tute spaziali AxEMU di Axiom Space pe...
Dongfeng sfida la NATO: navi dalla Cina ...
5G Standalone per il mondo marittimo: Er...
Nova Lake-S: configurazioni fino a 52 co...
Baxi presenta la pompa di calore Alya E ...
PC ASUS e Acer vietati in Germania: il t...
Stellantis rilancia il diesel in Europa:...
Truffa per utenti Trezor e Ledger: lette...
Wi-Fi 7 conveniente: FRITZ! lancia 4630,...
La Formula 1 dei robot tagliaerba miglio...
Il nuovo gioco del creatore di God of Wa...
Grok arriva sulle Tesla in Europa: l'int...
Assassin's Creed IV: Black Flag Remake p...
Il padre di God of War attacca Sons...
È operativo il primo computer qua...
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: 05:14.


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