Memory leak
Moderatore: Staff
Regole del forum
1) Citare in modo preciso il linguaggio di programmazione usato.
2) Se possibile portare un esempio del risultato atteso.
3) Leggere attentamente le risposte ricevute.
4) Scrivere i messaggi con il colore di default, evitare altri colori.
5) Scrivere in Italiano o in Inglese, se possibile grammaticalmente corretto, evitate stili di scrittura poco chiari, quindi nessuna abbreviazione tipo telegramma o scrittura stile SMS o CHAT.
6) Appena registrati è consigliato presentarsi nel forum dedicato.
La non osservanza delle regole porta a provvedimenti di vari tipo da parte dello staff, in particolare la non osservanza della regola 5 porta alla cancellazione del post e alla segnalazione dell'utente. In caso di recidività l'utente rischia il ban temporaneo.
1) Citare in modo preciso il linguaggio di programmazione usato.
2) Se possibile portare un esempio del risultato atteso.
3) Leggere attentamente le risposte ricevute.
4) Scrivere i messaggi con il colore di default, evitare altri colori.
5) Scrivere in Italiano o in Inglese, se possibile grammaticalmente corretto, evitate stili di scrittura poco chiari, quindi nessuna abbreviazione tipo telegramma o scrittura stile SMS o CHAT.
6) Appena registrati è consigliato presentarsi nel forum dedicato.
La non osservanza delle regole porta a provvedimenti di vari tipo da parte dello staff, in particolare la non osservanza della regola 5 porta alla cancellazione del post e alla segnalazione dell'utente. In caso di recidività l'utente rischia il ban temporaneo.
Memory leak
Esiste qualche tool che possa tornare utile quando si cercano memory leak ? Che magari traccia il modo in cui il programma alloca, libera o meno, usa la memoria ?
- conraid
- Staff
- Messaggi: 13630
- Iscritto il: gio 14 lug 2005, 0:00
- Nome Cognome: Corrado Franco
- Slackware: current64
- Desktop: kde
- Località: Livorno
- Contatta:
Re: Memory leak
http://www.slacky.eu/index.php?option=c ... &Itemid=56Dani ha scritto:Esiste qualche tool che possa tornare utile quando si cercano memory leak ? Che magari traccia il modo in cui il programma alloca, libera o meno, usa la memoria ?
Re: Memory leak
L'ho avviato usando --leak-check=full --log-file=log e nel sommario esce:
Non capisco come usare queste informazioni, e nemmeno le altre salvate nel file di log a dir la verità
Codice: Seleziona tutto
==5734== LEAK SUMMARY:
==5734== definitely lost: 3,013,859 bytes in 9,159 blocks.
==5734== indirectly lost: 37,719,580 bytes in 206,773 blocks.
==5734== possibly lost: 12,620 bytes in 14 blocks.
==5734== still reachable: 168,142 bytes in 668 blocks.
==5734== suppressed: 0 bytes in 0 blocks.
==5734== Reachable blocks (those to which a pointer was found) are not shown.
==5734== To see them, rerun with: --leak-check=full --show-reachable=yes
- targzeta
- Iper Master
- Messaggi: 6631
- Iscritto il: gio 3 nov 2005, 14:05
- Nome Cognome: Emanuele Tomasi
- Slackware: 64-current
- Kernel: latest stable
- Desktop: IceWM
- Località: Carpignano Sal. (LE) <-> Pisa
Re: Memory leak
Se il codice è C o C++ puoi usare la libreria mtrace (3) poi usi /usr/bin/mtrace per capire dove hai dimenticato di deallocare.Dani ha scritto:Esiste qualche tool che possa tornare utile quando si cercano memory leak ? Che magari traccia il modo in cui il programma alloca, libera o meno, usa la memoria ?
Spina
Se pensi di essere troppo piccolo per fare la differenza, prova a dormire con una zanzara -- Dalai Lama
- conraid
- Staff
- Messaggi: 13630
- Iscritto il: gio 14 lug 2005, 0:00
- Nome Cognome: Corrado Franco
- Slackware: current64
- Desktop: kde
- Località: Livorno
- Contatta:
Re: Memory leak
ehm... non sono un programmatore, ti ho solo suggerito un software che sento sempre nominare come "il tool" per certe cose. Ma non lo conoscoDani ha scritto: Non capisco come usare queste informazioni, e nemmeno le altre salvate nel file di log a dir la verità
Re: Memory leak
Ok usando mtrace ecco una parte del risultato:spina ha scritto:Se il codice è C o C++ puoi usare la libreria mtrace (3) poi usi /usr/bin/mtrace per capire dove hai dimenticato di deallocare.Dani ha scritto:Esiste qualche tool che possa tornare utile quando si cercano memory leak ? Che magari traccia il modo in cui il programma alloca, libera o meno, usa la memoria ?
Spina
Codice: Seleziona tutto
dani[]$ mtrace programma log
Memory not freed:
-----------------
Address Size Caller
0x08056378 0xa at 0xb7df4f90
0x08056388 0x100 at 0xb7e34bb3
0x08056490 0x38 at 0xb7e29ef2
0x080564d0 0x4 at 0xb7e27796
0x080564e0 0x4 at 0xb7e27796
0x08056540 0x40 at 0xb7e33619
0x08056588 0x4 at 0xb7e29075
0x08056598 0x8c at 0xb7e34505
0x08056628 0x1c8 at 0xb7e33217
0x080567f8 0x300 at 0xb7e3325d
0x08056b00 0x38 at 0xb7e29ef2
[...]
- targzeta
- Iper Master
- Messaggi: 6631
- Iscritto il: gio 3 nov 2005, 14:05
- Nome Cognome: Emanuele Tomasi
- Slackware: 64-current
- Kernel: latest stable
- Desktop: IceWM
- Località: Carpignano Sal. (LE) <-> Pisa
Re: Memory leak
Che non sei un bravo programmatore . comunque, guarda qui (ricordati di compilare il programma con "-g"):Dani ha scritto:...L'elenco è molto piu' lungo, ma a parte questo come devo interpretare questi dati ?
http://www.gnu.org/software/libtool/man ... races.html
Spina
Se pensi di essere troppo piccolo per fare la differenza, prova a dormire con una zanzara -- Dalai Lama
Re: Memory leak
Ho già visto quel link, ed il programma lo compilo usando l'opzione -g di gcc !spina ha scritto: Che non sei un bravo programmatore . comunque, guarda qui (ricordati di compilare il programma con "-g"):
http://www.gnu.org/software/libtool/man ... races.html
Spina
Inizialmente assieme ai problemi di memoria mi segnalava anche il file sorgente e la riga corrispondente, ma un volta corretti questi errori mi sono apparsi solamente indirizzi come sopra, e nient'altro
Ultima modifica di Dani il lun 3 mar 2008, 13:59, modificato 1 volta in totale.
- targzeta
- Iper Master
- Messaggi: 6631
- Iscritto il: gio 3 nov 2005, 14:05
- Nome Cognome: Emanuele Tomasi
- Slackware: 64-current
- Kernel: latest stable
- Desktop: IceWM
- Località: Carpignano Sal. (LE) <-> Pisa
Re: Memory leak
Allora molto probabilmente gli indirizzi appartengono ad una libreria che usi (e che quindi non è compilata con -g). Se fai un pacchettino del sorgente mandamelo che gli do un occhiata <spina80@freemail.it>.Dani ha scritto: Ho già visto quel link, ed il programma lo compilo usando l'opzione -g di gcc !
Inizialmente assieme ai problemi di memoria mi segnalava anche il file sorgente e la riga corrispondente, ma un volta corretti questi errori mi sono appariti solamente indirizzi come sopra, e nient'altro
Spina
Se pensi di essere troppo piccolo per fare la differenza, prova a dormire con una zanzara -- Dalai Lama
Re: Memory leak
Finalmente ho capito dove stava il grosso baco ! Dopo una funzione che effettuava qualche chiamata a regcomp() e regexec() anzichè dare un regfree() per ogni chiamata, ne davo uno solo all'uscita della funzione !
Infatti richiamando la funzione incriminata un migliaio di volte, la ram andava velocemente a farsi benedire. Ora invece per quante volte possa chiamare la funzione il consumo di ram è quasi irrisorio (un paio di mega, il codice è ancora da ottimizzare).
Comunque sia QUI trovi i sorgenti del programma, è la versione di sviluppo quindi non è testata in tutte le funzioni. Se ci butti un occhio e tiri fuori qualche consiglio ovviamente non puo' che farmi piacere :)
Infatti richiamando la funzione incriminata un migliaio di volte, la ram andava velocemente a farsi benedire. Ora invece per quante volte possa chiamare la funzione il consumo di ram è quasi irrisorio (un paio di mega, il codice è ancora da ottimizzare).
Comunque sia QUI trovi i sorgenti del programma, è la versione di sviluppo quindi non è testata in tutte le funzioni. Se ci butti un occhio e tiri fuori qualche consiglio ovviamente non puo' che farmi piacere :)