Strumenti Utente

Strumenti Sito


informatica:sol:laboratorio16:esercitazionia:esercitazione2

Differenze

Queste sono le differenze tra la revisione selezionata e la versione attuale della pagina.

Link a questa pagina di confronto

Entrambe le parti precedenti la revisioneRevisione precedente
Prossima revisione
Revisione precedente
informatica:sol:laboratorio16:esercitazionia:esercitazione2 [29/02/2016 alle 19:11 (9 anni fa)] Massimo Torquatiinformatica:sol:laboratorio16:esercitazionia:esercitazione2 [02/03/2016 alle 20:45 (9 anni fa)] (versione attuale) Massimo Torquati
Linea 1: Linea 1:
 ====== Esercitazione 2 ====== ====== Esercitazione 2 ======
  
-Stringhe e libreria standard di IO, creazione di librerie statiche.+Stringhe e libreria standard di IO, creazione di librerie statiche, uso di ''valgrind''.\\
  
-Cercare di completare tutti gli esercizi durante le ore di laboratorio e nel caso come homework.\\ 
  
 ===== Esercizio 1: tokenizer ===== ===== Esercizio 1: tokenizer =====
  
-Scrivere un programma che data una stringa come argomento, stampi a video ('stdout') le parole contenute nella stringa in input una per linea. Usare la funzione di libreria 'strtok'. Per realizzare il programma implementare la funzione 'tokenizer' con la seguente segnatura:+Scrivere un programma che data una stringa come argomento, stampa a video (''stdout'') le parole contenute nella stringa in input una per ogni linea. Usare la funzione di libreria 'strtok' per estrarre i token dalla stringa. Per realizzare il programma implementare la funzione 'tokenizer' con la seguente segnatura:
 <code> <code>
 void tokenizer(char *stringa, FILE *out); void tokenizer(char *stringa, FILE *out);
Linea 22: Linea 21:
 ===== Esercizio 2: tokenizer_r ===== ===== Esercizio 2: tokenizer_r =====
  
-Scrivere una seconda versione del programma precedente che implementa la funzione 'tokenizer_r' che ha la stessa identica interfaccia ma che utilizza al suo interno 'strtok_r'. Quali sono le principali differenze tra 'tokenizer' e 'tokenizer_r' ? (Suggerimento: partire dall'analisi accurata del 'man' di 'strtok_r').+Scrivere una seconda versione del programma precedente che implementa la funzione 'tokenizer_r' che ha la stessa identica interfacciama che utilizza al suo interno ''strtok_r'' invece di ''strtok''. Quali sono le principali differenze tra 'tokenizer' e 'tokenizer_r' ? (Suggerimento: leggere con attenzione il ''man'' di ''strtok_r'').
  
-NOTA: se si compila con '-std=c99' per evitare il warning ''implicit declaration of function 'strtok_r'...'' aggiungere la seguente opzione di compilazione '-D_POSIX_C_SOURCE=199309L'.+NOTA: se si utilizza l'opzione ''-std=c99'', per evitare i warnings del tipo ''implicit declaration of function 'strtok_r'...'' aggiungere la seguente opzione di compilazione ''-D_POSIX_C_SOURCE=200112L''. La funzione strtok_r fa parte dello standard POSIX-2001
  
 ===== Esercizio 3: tokenizer_rfile ===== ===== Esercizio 3: tokenizer_rfile =====
  
-Scrivere un programma C che prende in input 3 argomenti, i primi due argomenti sono obbligatori, il terzo e' opzionale. Il primo argomento è il nome di un file di input in formato testuale contenente stringhe di parole. Ogni stringa  ha una lunghezza massima pari a 1024 caratteri. Il secondo argomento corrisponde ad un file di output che dovra' contenere tutte le parole del primo file, una per ogni riga. Se il file di input non esiste il programma dovrà ritornare un messaggio opportuno di errore sullo standard error. Se il file di output esiste questo dovra' essere sovrascritto se il terzo argomento del programma non è stato specificato oppure se è diverso dal carattere 'a'. Se il terzo argomento è uguale al carattere 'a' l'output del programma dovrà essere appeso in fondo.+Scrivere un programma C che prende in input 3 argomenti, i primi due argomenti sono obbligatori, il terzo e' opzionale. Il primo argomento è il nome di un file di input in formato testuale contenente stringhe di parole. Ogni stringa  ha una lunghezza massima pari a 1024 caratteri. Il secondo argomento corrisponde ad un file testuale di output che dovra' contenere tutte le parole del primo file, scritte al contrario una per ogni riga. Se il file di input non esisteil programma dovrà ritornare un messaggio di errore opportuno sullo standard error (stderr). Se il file di output esiste questo dovra' essere sovrascritto se il terzo argomento del programma non è stato specificatooppure se tale argomento è diverso dal carattere 'a'. Se il terzo argomento è uguale al carattere 'a' l'output del programma dovrà essere appeso in fondo al file.
  
-===== Esercizio 4: libtokenizer.a =====+===== Esercizio 4: valgrind =====
  
-Inserire nel file 'tokenizer.h' l'interfaccia delle due funzioni 'tokenizer' e 'tokenizer_r' come descritte negli esercizi 1 e 2. Inserire nel file 'tokenizer.c' l'implementazione delle due funzioni. Creare quindi una librerie statica 'libtokenizer.a' e riscrivere il programma dell'esercizio precedente in modo che il programma main includa il file 'tokenizer.h' e linki la libreria. +Verificare la correttezza degli accessi in memoria utilizzando ''valgrind'' del programma realizzato nell'esercizio 3. Verificare che non ci siano memory leaks all'uscita del programma. 
 + 
 +Valgrind permette, fra l'altro, di capire se le variabili sono inizializzate prima del loro uso, se accediamo a memoria gia' deallocata o mai allocata o a zone non inizializzate.  
 + 
 +Passi:   
 +  * compilare il file da verificare con opzione ''-g'' per includere le informazioni di debugging (anche se non è strettamente necessario).  
 +  * eseguire il programma con ''valgrind'' nel modo seguente : 
 +<code> 
 +bash$ valgrind ./prova 
 +</code> 
 +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. 
 + 
 +Se si specifica l'opzione ''--leak-check=full'' (attenzione al doppio trattino), valgrind fornirà dettagli per ogni blocco di memoria che non è più raggiungibile o che pur essendo raggiungibile non è stato liberato, dando anche l'informazione di dove il blocco è stato allocato. 
 + 
 +===== Esercizio 5: libtokenizer.a ===== 
 + 
 +Inserire nel file 'tokenizer.h' l'interfaccia delle due funzioni 'tokenizer' e 'tokenizer_r' come descritte negli esercizi 1 e 2. Inserire nel file 'tokenizer.c' l'implementazione delle due funzioni. Creare quindi una librerie statica 'libtokenizer.a' e riscrivere il programma dell'esercizio in modo che il programma main includa il file 'tokenizer.h' e linki la libreria. 
  
  
  
  
informatica/sol/laboratorio16/esercitazionia/esercitazione2.1456773064.txt.gz · Ultima modifica: 29/02/2016 alle 19:11 (9 anni fa) da Massimo Torquati

Donate Powered by PHP Valid HTML5 Valid CSS Driven by DokuWiki