fisica:informatica:201415:esercitazioni:esercitazione8
Differenze
Queste sono le differenze tra la revisione selezionata e la versione attuale della pagina.
Entrambe le parti precedenti la revisioneRevisione precedenteProssima revisione | Revisione precedente | ||
fisica:informatica:201415:esercitazioni:esercitazione8 [03/02/2015 alle 16:07 (10 anni fa)] – [Esercizio 3: Altre funzioni su liste di double] Susanna Pelagatti | fisica:informatica:201415:esercitazioni:esercitazione8 [03/02/2015 alle 16:38 (10 anni fa)] (versione attuale) – [Esercizio 3: Altre funzioni su liste di double] Susanna Pelagatti | ||
---|---|---|---|
Linea 3: | Linea 3: | ||
===== Esercizio 1: Sequenze di double ===== | ===== Esercizio 1: Sequenze di double ===== | ||
Consideriamo il problema di leggere da standard input una sequenza di valori reali terminata da 0.0 creando la lista corrispondente di tipo | Consideriamo il problema di leggere da standard input una sequenza di valori reali terminata da 0.0 creando la lista corrispondente di tipo | ||
- | < | + | < |
typedef struct lista_d { | typedef struct lista_d { | ||
double val; | double val; | ||
Linea 10: | Linea 10: | ||
</ | </ | ||
* sviluppare un programma C che legge gli elementi dallo standard input usando una funzione | * sviluppare un programma C che legge gli elementi dallo standard input usando una funzione | ||
- | < | + | < |
- | double leggi_nuovo_valore(void) | + | double leggi_nuovo_valore(void); |
</ | </ | ||
- | inserendo | + | il programma inserisce |
* Modificare il precedente programma in modo da inserire ogni nuovo valore in coda alla lista stampando la lista risultante sullo standard output | * Modificare il precedente programma in modo da inserire ogni nuovo valore in coda alla lista stampando la lista risultante sullo standard output | ||
+ | |||
===== Esercizio 2: Funzioni di inserzione su liste di double ===== | ===== Esercizio 2: Funzioni di inserzione su liste di double ===== | ||
Consideriamo le funzioni | Consideriamo le funzioni | ||
- | < | + | < |
lista_d_t * inserisci_testa ( lista_d_t * l, double v); | lista_d_t * inserisci_testa ( lista_d_t * l, double v); | ||
lista_d_t * inserisci_coda ( lista_d_t * l, double v); | lista_d_t * inserisci_coda ( lista_d_t * l, double v); | ||
Linea 29: | Linea 30: | ||
===== Esercizio 3: Altre funzioni su liste di double ===== | ===== Esercizio 3: Altre funzioni su liste di double ===== | ||
Implementare le seguenti funzioni in modo iterativo e ricorsivo: | Implementare le seguenti funzioni in modo iterativo e ricorsivo: | ||
- | < | + | < |
/** calcola e restituisce il massimo della lista l */ | /** calcola e restituisce il massimo della lista l */ | ||
double max ( lista_d_t * l); | double max ( lista_d_t * l); | ||
Linea 35: | Linea 36: | ||
double somma ( lista_d_t * l); | double somma ( lista_d_t * l); | ||
/** libera la memoria occupata dalla lista */ | /** libera la memoria occupata dalla lista */ | ||
- | void fee_list( lista_d_t * l); | + | void free_list( lista_d_t * l); |
/** cancella, se presente, l' | /** cancella, se presente, l' | ||
- | del valore | + | del valore |
e restituisce la nuova lista */ | e restituisce la nuova lista */ | ||
- | lista_d_t * cancella ( lista_d_t * l, double v); | + | lista_d_t |
+ | /** cancella | ||
+ | del valore v dalla lista l (liberando la memoria) | ||
+ | e restituisce la nuova lista */ | ||
+ | lista_d_t * cancella_tutti | ||
</ | </ | ||
Linea 55: | Linea 60: | ||
* inserire la chiamata alla funzione di libreria muntrace() alla fine della parte del programma C che vogliamo verificare | * inserire la chiamata alla funzione di libreria muntrace() alla fine della parte del programma C che vogliamo verificare | ||
* compilare il file da verificare con opzione '' | * compilare il file da verificare con opzione '' | ||
- | < | + | < |
bash$ gcc -Wall -pedantic -g -o prova main.c | bash$ gcc -Wall -pedantic -g -o prova main.c | ||
</ | </ | ||
* settare la variabile di ambiente '' | * settare la variabile di ambiente '' | ||
- | < | + | < |
bash$ export MALLOC_TRACE=./ | bash$ export MALLOC_TRACE=./ | ||
</ | </ | ||
* eseguire, nel nostro esempio con: | * eseguire, nel nostro esempio con: | ||
- | < | + | < |
bash$ ./prova | bash$ ./prova | ||
</ | </ | ||
* dopo l' | * dopo l' | ||
- | < | + | < |
bash$ mtrace ./prova ./ | bash$ mtrace ./prova ./ | ||
</ | </ | ||
questo rispondera' | questo rispondera' | ||
+ | ===== Esercizio 5: verificare gli accessi in memoria: valgrind ===== | ||
+ | |||
+ | Verificare la correttezza degli accessi ai puntatori compiuti dalle funzioni su liste utilizzando '' | ||
+ | Questo strumento permette fra l' | ||
+ | |||
+ | |||
+ | Per fare questo procedere come segue: | ||
+ | * compilare il file da verificare con opzione '' | ||
+ | <code bash> | ||
+ | bash$ gcc -Wall -pedantic -g -o prova main.c | ||
+ | </ | ||
+ | * eseguire | ||
+ | <code bash> | ||
+ | bash$ valgrind ./prova | ||
+ | </ | ||
+ | in questo modo, a schermo verranno riportare le infrazioni rilevate. Ad esempio, //invalid read// o //invalid write// sono accessi in lettura o scrittura a memoria non allocata o gia' deallocata. | ||
+ | |||
+ | '' |
fisica/informatica/201415/esercitazioni/esercitazione8.1422979643.txt.gz · Ultima modifica: 03/02/2015 alle 16:07 (10 anni fa) da Susanna Pelagatti