MEMORIA DINAMICA. & Indirizzo * Contenuto. 1. Puntatori. Nozioni base sull uso dei puntatori: Operatori & * In sintesi : /* Definizine variabili */
|
|
- Daniella Barbieri
- 5 anni fa
- Visualizzazioni
Transcript
1 MEMORIA DINAMICA 1. Puntatori Nozioni base sull uso dei puntatori: Operatori & * ES /* Definizine variabili */ int x, y; /* Variabili intere */ int *px; /* Puntatore a intero */ x = 10; /* Assegno 10 a x */ px = &x; /* px punta all indirizzo di x */ y = *px; /* Ora y = x = 10 */ /* Gli operatori sono complementari */ *(&x) = x; &(*px) = px; In sintesi : & Indirizzo * Contenuto 1
2 2. Puntatori e vettori Il nome del vettore è equivalente all indirizzo del suo primo elemento. vett = & vett[0] ES /* Definzione delle variabili */ int b[5]; int *bptr; bptr = b ; bptr = &b[0]; Quindi: b[3] *(bptr+3); *(b+3); &b[3] bptr+3; b+3; b[1] bptr[1] 3. Vettori e stringhe ES char color[] = blue ; char *color = blue ; char *s; = char s[]; 2
3 4. Vettori dinamici Parliamo di vettori dinamici quando non sappiamo esattamente la lunghezza del vettore. In C è possibile effettuare tale operazione utilizzando la memoria dinamica. ES /* Definizione variabili */ int num_elem; /* Lunghezza del vettore letto de file o da tastiera */ int *vett; /* Definizione di vettore dinamico */ void main(void) /* Allocazione */ vett = (int *)malloc( num_elem * sizeof(int) ); /* Lettura numeri */ for(i=0; i<num_elem; i++) printf( ); scanf( %d, &vett[i]); /* Deallocazione */ free(vett); 3
4 5. Vettori di puntatori I vettori di puntatori di solito vengono utilizzati con le stringhe. Sono utilissimi in casi come in figura: V[0] pippo V[1] pluto V[2] qui V[3] quo Con i vettori di puntatori posso evitare di sovradimensionare le colonne di una matrice di caratteri, ma ogni elemento del vettore sarà un puntatore ad una stringa allocata dinamicamente. CASO 1: Conosco già la lunghezza del vettore ES /* Definizioni di variabili */ #define N 10 char *vett[n]; /* Vettore di puntatori dimensionato */ void main(void) /* Lettura stringhe da tastiera */ for( i=0; i<n; i++) scanf( %s, stringa); /* Allocazione */ vett[i] = (char *)malloc( (strlen(stringa)+1) * (sizeof(char)) ); strcpy( vett[i], stringa); /* Deallocazione */ for( i=0; i<n; i++) free(vett[i]); 4
5 CASO 2: Non conosco la lunghezza del vettore ES /* VETTORE DINAMICO + VETTORE DI PUNTATORI */ /* Definizione variabili */ char temp[20]; /* Stringa temporanea */ char **vett; /* Vettore di puntatori - si ignora la lunghezza*/ int num_elem; /* Lunghezza vettore introdotta da tastiera o da file */ void main(void) /* Allocazione VETTORE DINAMICO */ vett = (char **)malloc( num_elem * (sizeof(char *)) ); /* A questo punto è come se avessi *vett[num_elem] */ /* Lettura stringhe da tastiera */ for( i=0; i<num_elem; i++ ) scanf( %s, temp); /* Allocazione VETTORE DI PUNTATORI */ vett[i] = (char *)malloc( (strlen(temp)+1) * (sizeof(char)) ); strcpy( vett[i], temp ); /* Deallocazione */ for( i=0; i<n; i++) free(vett[i]); free(vett); 5
6 SINTESI FINALE: Vettore dinamico Non si conosce la sua lunghezza. (num_elem). Formato di solito da numeri. int *vett; Vettore di puntatori Si conosce la lunghezza, ma non la profondità. Formato di solito da stringhe. char *vett[max_righe]; Vettore dinamico + Non si conosce né lunghezza né profondità. Vettore di puntatori È una fusione dei due casi precedenti char **vett; Qui di seguito sono riportati per intero programmi che utilizzano i meccanismi precedentemente illustrati. 6
7 /* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * Alessandro Fassio Ingegneria elettronica * * VETTORE DINAMICO * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */ #include <stdio.h> #include <conio.h> #include <string.h> #include <ctype.h> #include <alloc.h> void main (void) int n; int i; int *vett; clrscr(); printf("vettore DINAMICO - acquisizione numeri\n\n"); printf("inserire numero di elementi del vettore\n>> "); scanf("%d", &n); /* Allocazione */ vett = (int *)malloc( n * sizeof(int) ); if(vett == NULL) printf("errore in allocazione!!\n"); for(i=0; i<n; i++) printf("input vett[%d]: ", i+1); scanf("%d", &vett[i]); /* Stampa vettore introdotto */ for(i=0; i<n; i++) printf(" %d ", vett[i]); printf("\nfine\n"); free(vett); 7
8 /* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * Alessandro Fassio Ingegneria elettronica * * VETTORE DI PUNTATORI * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */ #include <stdio.h> #include <conio.h> #include <string.h> #include <ctype.h> #include <alloc.h> #define N 9 #define MAX 15 void main (void) char *vett[n]; char nome[max]; int i; clrscr(); printf("vettore DI PUNTATORI - acquisizione stringhe\n\n"); for(i=0; i<n; i++) printf("input elemento %d: ", i+1); scanf("%s", nome); /* Allocazione */ vett[i] = (char *)malloc( (strlen( nome ) +1) * sizeof(char)); if( vett[i]==null ) printf("errore in allocazione!!\n"); strcpy( vett[i], nome); /* Stampa di controllo */ printf("\nnomi introdotti:\n"); for( i=0; i<n; i++) printf("%s\n", vett[i]); printf("\nfine\n"); /* Deallocazione */ for( i=0; i<n; i++) free(vett[i]); 8
9 /* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * Alessandro Fassio Ingegneria elettronica * * VETTORE DINAMICO + VETTORE DI PUNTATORI * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */ #include <stdio.h> #include <conio.h> #include <string.h> #include <alloc.h> #define N 15 void main (void) int i; char str[n]; int n; /*Numero di dati che voglio introdurre */ char **vett; /*Vettore dinamico e di puntatori */ clrscr(); printf("vettore DINAMICO E DI PUNTATORI - con stringhe\n\n"); printf("introdurre numero di dati:\n"); scanf("%d", &n); /* Allocazione vettore dinamico */ vett = (char **)malloc( n * sizeof(char *) ); if( vett == NULL ) printf("errore in allocazione.\n"); for( i=0; i<n; i++) printf("input stringa %d: ", i+1); scanf("%s", str); /* Allocazione vettore di puntatori */ vett[i] = (char *)malloc( (strlen(str)+1) * sizeof(char)); 9
10 if( vett[i] == NULL ) printf("errore in allocazione.\n"); strcpy( vett[i], str); /* Stampa */ printf("nomi introdotti:\n"); for(i=0; i<n; i++) printf("%s\n", vett[i]); printf("\nfine\n"); /* Deallocazione */ for(i=0; i<n; i++) free(vett[i]); free(vett); 10
11 /* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * Alessandro Fassio Ingegneria elettronica * * Lettura e stampa classifica di calcio * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */ VETTORE DINAMICO + STRUCT (con campi statici) #include <stdio.h> #include <conio.h> #include <string.h> #include <alloc.h> typedef struct char nome_sq[30]; int punti; classifica; classifica *vett; char nome_file[30]; int num_squadre; /* Prototipi */ void errore(void); int leggi_file(void); void stampa(int num_squadre); void main (void) clrscr(); printf("inserisci il nome del file:\n"); scanf("%s", nome_file); num_squadre = leggi_file(); printf("\n CLASSIFICA:\n\n"); stampa(num_squadre); printf("\nfine\n\n"); free(vett); /************************************************************************ ERRORE *************************************************************************/ void errore(void) printf("errore!!\n"); 11
12 /************************************************************************ LETTURA FILE *************************************************************************/ /* file: A:\S.TXT */ int leggi_file(void) FILE *fptr; int squadre=0, i, npunti; fptr=fopen( nome_file, "r"); if( fptr==null ) errore(); /* Leggo quante squadre ci sono nel file */ fscanf(fptr, "%d", &squadre); /* Allocazione */ vett = (classifica *)malloc( squadre * sizeof(classifica) ); if( vett==null ) errore(); /* Lettura e memorizzazione nella struct */ for( i=0; i<squadre; i++) fscanf( fptr,"%s %d", vett[i].nome_sq, &vett[i].punti); fclose(fptr); return(squadre); /************************************************************************ STAMPA *************************************************************************/ void stampa(int num_squadre) int i; for(i=0; i<num_squadre; i++) printf("%-16s %d\n", vett[i].nome_sq, vett[i].punti); return; 12
13 /* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * Alessandro Fassio Ingegneria elettronica * * VETTORE DIN-PUNT CON STRUCT (campi statici e dinamici) * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */ #include <stdio.h> #include <conio.h> #include <string.h> #include <alloc.h> typedef struct char *nome; char *cognome; int cod; persona; persona *vett; char s1[20], s2[20]; char nome_file[20]; void main (void) int i, n, dato; FILE *fptr; clrscr(); printf("nome file.\n >> "); scanf("%s", nome_file); /* Apertura del file A:\P.TXT */ fptr=fopen(nome_file, "r"); if( fptr==null ) printf("errore apertura file\n"); fscanf(fptr, "%d", &n); 13
14 /* Allocazione vettore dinamico */ vett = (persona *)malloc( n *sizeof(persona)); if(vett==null) printf("errore allocazione 1\n"); /* Lettura file */ for(i=0; i<n; i++) fscanf(fptr, "%s %s %d", s1, s2, &dato); /* Allocazione vettore di puntatori*/ vett[i].nome = (char *)malloc( (sizeof(char)) * (strlen(s1)+1) ); vett[i].cognome = (char *)malloc( (sizeof(char)) * (strlen(s2)+1) ); if( (vett[i].cognome==null) (vett[i].nome==null) ) printf("errore allocazione 2\n"); strcpy(vett[i].nome, s1); strcpy(vett[i].cognome, s2); vett[i].cod=dato; fclose(fptr); /* Stampa */ for(i=0; i<n; i++) printf("%-15s %-15s %d\n", vett[i].nome, vett[i].cognome, vett[i].cod); /* Deallocazione */ for(i=0; i<n; i++) free(vett[i].nome); free(vett[i].cognome); free(vett); 14
L'allocazione dinamica della memoria
L'allocazione dinamica della memoria Fulvio CORNO - Matteo SONZA REORDA Dip. Automatica e Informatica Politecnico di Torino I puntatori Le variabili di tipo puntatore permettono di accedere alla memoria
DettagliL'allocazione dinamica della memoria
L'allocazione dinamica della memoria Fulvio CORNO - Matteo SONZA REORDA Dip. Automatica e Informatica Politecnico di Torino I puntatori Le variabili di tipo puntatore permettono di accedere alla memoria
DettagliAllocazione dinamica della memoria
Allocazione dinamica della memoria Allocazione statica: limiti Per quanto sappiamo finora, in C le variabili sono sempre dichiarate staticamente la loro esistenza deve essere prevista e dichiarata a priori
DettagliPuntatori. Un puntatore contiene un numero che indica la locazione di memoria dove è presente la variabile puntata
Puntatori int i = 10; int * pi = &i; pi i = 10 116 int * pi = pi contiene un informazione che mi permette di accedere ( puntare ) ad una variabile intera Un puntatore contiene un numero che indica la locazione
Dettagli- matrici - stringhe - file (lettura/scrittura, di testo/binari) - strutture, puntatori - allocazione dinamica della memoria (malloc)
Esercitazione Argomenti che verranno trattati in questa esercitazione: - matrici - stringhe - file (lettura/scrittura, di testo/binari) - strutture, puntatori - allocazione dinamica della memoria (malloc)
DettagliIl compito del 11 novembre 2004
Alcuni errori frequenti riscontrati durante la correzione del compito: 1. In alcuni elaborati il typedef/struct non è stato utilizzato correttamente 2. Molti hanno confuso la dichiarazione di un array,
DettagliLaboratorio di Algoritmi e Strutture Dati
Laboratorio di Algoritmi e Strutture Dati Funzioni standard del C: Funzioni di I/O Allocazione dinamica della memoria Funzioni su stringhe di caratteri Testo di riferimento B.W. Kernighan & D.M. Ritchie
DettagliAritmetica dei puntatori
Aritmetica dei puntatori Marco Alberti Programmazione e Laboratorio, A.A. 2016-2017 Dipartimento di Matematica e Informatica - Università di Ferrara Ultima modifica: 7 dicembre 2016 sizeof L operatore
DettagliEsercizi di programmazione in linguaggio C English Dictionary
Esercizi di programmazione in linguaggio C English Dictionary Il file di testo wordnet.txt contiene un certo numero di parole (word) e il corrispondente significato (meaning) secondo il seguente formato:
DettagliEsercizio 1 File: ordinamento di un archivio di studenti (file binario)
Esercitazione Fondamenti di Informatica B Corso di Laurea in Ingegneria Meccanica 9 Esercitazione: 19 gennaio 2005 Esercizi sui file e sulle liste. Scaletta Esercizio 1 File: ordinamento di un archivio
DettagliArray. Maurizio Palesi Salvatore Serrano. In C si possono definire tipi strutturati Vi sono due costruttori fondamentali
MASTER Information Technology Excellence Road (I.T.E.R.) Array Maurizio Palesi Salvatore Serrano Master ITER Informatica di Base Maurizio Palesi, Salvatore Serrano 1 Tipi di dato stutturati In C si possono
Dettagliint ninv; /* numero di inventario */
1) Scrivere il programma C che legga da un file di testo ("dati.dat") i record con dati relativi ad un archivio di dischi (utilizzando la struttura data) e scriva il file dati1.dat con i nomi degli artisti
DettagliFondamenti di Informatica: Ingegneria Meccanica Prova scritta del 11 aprile 2008
Fondamenti di Informatica: Ingegneria Meccanica Prova scritta del 11 aprile 2008 Gli studenti dell a.a. 2007-2008 e 2006-2007 (6CFU) devono svolgere i 7 esercizi marcati 6CFU e 3/6 CFU. Gli studenti degli
DettagliAllocazione dinamica della memoria (2)
Allocazione dinamica della memoria (2) 1 Allocazione dinamica e funzioni Con il seguente programma si vorrebbe allocare dinamicamente un vettore all interno di una funzione (leggi_vettore) void leggi_vettore(int
DettagliLinguaggio C - Array. Array: tipo nome_array[num_elementi]
Linguaggio C - Array Array: Gli array o vettori sono delle strutture dati in grado di contenere un insieme di valori tutti dello stesso tipo. Un array lo possiamo immaginare come un contenitore suddiviso
DettagliFondamenti di Informatica: Ingegneria Meccanica SOLUZIONI 26 marzo 2008
Fondamenti di Informatica: Ingegneria Meccanica SOLUZIONI 26 marzo 2008 Gli studenti dell a.a. 2007-2008 e 2006-2007 (6CFU) devono svolgere i 7 esercizi marcati 6CFU e 3/6 CFU. Gli studenti degli anni
DettagliFondamenti di Informatica L-A
Fondamenti di Informatica L-A Esercitazione del 23/11/07 Ing. Giorgio Villani Ripasso Teoria Funzioni ricorsive 2 fatt(2) 1 2*fatt(1) fatt(1) 1 2*1 1*fatt(0) fatt(0) 1*1 caso base fatt(0)=1 Esercizio 1
DettagliEsempio di costruzione di una classe: un dizionario
Esempio di costruzione di una classe: un dizionario Problema: si vuole disporre di un dizionario per tradurre parole dall italiano in un altra lingua e viceversa. Il dizionario deve consentire di ottenere
DettagliEsercizio 1: Puntatori impiegati che sono manager
Esercitazione Fondamenti di Informatica B Corso di Laurea in Ingegneria Meccanica 10 Esercitazione: 25 gennaio 2006 Esercizi di riepilogo Problema: Esercizio 1: Puntatori impiegati che sono manager Si
DettagliLezione 8: Stringhe ed array multidimensionali
Lezione 8: Stringhe ed array multidimensionali Vittorio Scarano Corso di Laurea in Informatica Università degli Studi di Salerno Struttura della lezione AVVISO: la lezione di laboratorio di 28/5 non si
DettagliI puntatori e l allocazione dinamica di memoria
I puntatori e l allocazione dinamica di memoria L allocazione delle variabili Allocazione e rilascio espliciti di memoria Le funzioni malloc e free 2 2006 Politecnico di Torino 1 Allocare = collocare in
DettagliIl linguaggio C. Puntatori e dintorni
Il linguaggio C Puntatori e dintorni 1 Puntatori : idea di base In C è possibile conoscere e denotare l indirizzo della cella di memoria in cui è memorizzata una variabile (il puntatore) es : int a = 50;
DettagliI puntatori e l allocazione dinamica di memoria
I puntatori e l allocazione dinamica di memoria Allocazione dinamica di memoria L allocazione delle variabili Allocazione e rilascio espliciti di memoria Le funzioni malloc e free 2 Allocazione dinamica
DettagliFUNZIONI DI MANIPOLAZIONE DELLE LISTE
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * Alessandro Fassio Ingegneria elettronica * * FUNZIONI DI MANIPOLAZIONE DELLE LISTE * * * * * * * * * * * * * * * * * * * * * *
DettagliStringhe e allocazione dinamica della memoria
Stringhe e allocazione dinamica della memoria Esercizio Scrivere un programma strings.c che legge da standard input una sequenza di parole separate da uno o più spazi, e stampa le parole lette, una per
DettagliQualche esempio di programmi in C. E Mumolo - DIA
Qualche esempio di programmi in C E Mumolo - DIA Passaggio di strutture a una funzione per valore int num_mat; char nome[20]; studente; void func(studente record); studente record; record.num_mat=1; strcpy(record.nome,
DettagliLezione 12: Allocazione Dinamica della Memoria
Lezione 12: Allocazione Dinamica della Memoria Laboratorio di Elementi di Architettura e Sistemi Operativi 17 Aprile 2013 Puntatori e vettori Puntatori ed indirizzi Semplificando, la memoria di un computer
DettagliStrutture Dati Dinamiche
Strutture Dati Dinamiche Motivazioni Le variabili considerate fino a questo punto devono essere dichiarate staticamente, ossia la loro esistenza, il loro nome e la loro dimensione devono essere previsti
DettagliPuntatori e Heap in C. Prof.Ing.S.Cavalieri
Puntatori e Heap in C Prof.Ing.S.Cavalieri Tipi Puntatori #include int n; int * p; int main(void) { n = 15; p = &n; NULL int n, *p; printf("\nil Numero n e' uguale a : %d ",n); *p = 25; printf("\nil
DettagliL'Allocazione Dinamica della Memoria nel linguaggio C
L'Allocazione Dinamica della Memoria nel linguaggio C Prof. Rio Chierego riochierego@libero.it http://www.riochierego.it/informatica.htm Sommario Questo documento tratta l'allocazione dinamica della memoria
DettagliCorso di Informatica A.A
Corso di Informatica A.A. 2009-2010 Lezione 11 Corso di Informatica 2009-2010 Lezione 11 1 Utilizzo dei puntatori Funzioni Perche i Puntatori? I puntatori hanno tre importanti applicazioni: 1. Passaggio
DettagliESERCIZIO: SHIFT ARRAY (1)
ARRAY E STRINGHE ARRAY ESERCIZIO: SHIFT ARRAY (1) Utilizzando le funzioni scrivere un programma che: genera una sequenza di N = 20 numeri interi e li memorizza in un array ( riempi_array( )) visualizza
DettagliAllocazione dinamica della memoria: calloc() Se T è il nomed di un tipo, la chiamata calloc(n, sizeof(t)) è equivalente a malloc(n * sizeof(t))
Allocazione dinamica della memoria: malloc() In C è possibile allocare dinamicamente un area di memoria (ossia, durante l esecuzione di un programma) tramite le funzioni malloc() e calloc() (occorre includere
DettagliLezione di Laboratorio di Prgrammazione: /04/2019 a.a. 2018/2019 R.Prevete
Lezione di Laboratorio di Prgrammazione: 15 09/04/2019 a.a. 2018/2019 R.Prevete Dati aggregati: struct Dicharazione di struttura con identificatore: struct { ;
DettagliUnità Didattica 4 Linguaggio C. Vettori. Puntatori. Funzioni: passaggio di parametri per indirizzo.
Unità Didattica 4 Linguaggio C Vettori. Puntatori. Funzioni: passaggio di parametri per indirizzo. 1 Vettori Struttura astratta: Insieme di elementi dello stesso tipo, ciascuno individuato da un indice;
DettagliCaratteri e stringhe
Caratteri e stringhe Caratteri Dato che un computer può memorizzare esclusivamente sequenze di bit, per memorizzare un carattere (e quindi testi) è necessario stabilire una convenzione che associa a un
DettagliIntroduzione al C. Lezione 4 Allocazione dinamica della memoria. Rossano Venturini. Pagina web del corso
Introduzione al C Lezione 4 Allocazione dinamica della memoria Rossano Venturini rossano@di.unipi.it Pagina web del corso http://didawiki.cli.di.unipi.it/doku.php/informatica/all-b/start Lezioni di ripasso
DettagliIntroduzione. L elaborazione dei files in C. Elaborazione dei files (1) Elaborazione dei files (2) D.D. cap. 11+ pp K.P. pp.
Introduzione L elaborazione dei files in C D.D. cap. 11+ pp. 569-572 K.P. pp. 581-583 La memorizzazione dei dati nelle variabili e nei vettori è temporanea: tutti quei dati andranno persi quando il programma
DettagliFondamenti di Informatica: Ingegneria Meccanica Prova scritta del 12 luglio 2008
Fondamenti di Informatica: Ingegneria Meccanica Prova scritta del 12 luglio 2008 Gli studenti dell a.a. 2007-2008 e 2006-2007 (6CFU) devono svolgere i 6 esercizi. Gli studenti degli anni precedenti non
DettagliAllocazione dinamica memoria
Allocazione dinamica memoria Marco Casazza 11/12/2017 1 Esercizio 1 1 /* 2 Creare una lista bidirezionale di interi, ovvero una lista 3 che permette lo scorrimento in entrambe le direzioni ( dal primo
DettagliIntroduzione al linguaggio C Puntatori
Introduzione al linguaggio C Puntatori Violetta Lonati Università degli studi di Milano Dipartimento di Informatica Laboratorio di algoritmi e strutture dati Corso di laurea in Informatica 19 ottobre 2017
DettagliLezione XI Le stringhe
Programmazione e Laboratorio di Programmazione Lezione XI Le stringhe Programmazione e Laboratorio di Programmazione: Le stringhe 1 Premessa: Il tipo char Dimensione: 1 byte Range: da 0 a 255 Definizione:
DettagliCorso di Fondamenti di Programmazione canale E-O. Introduzione. Elaborazione dei files (2)
Corso di Fondamenti di Programmazione canale E-O Tiziana Calamoneri L elaborazione dei files in C DD, Cap. 11 + pp. 569-572 KP, pp. 581-583 Introduzione La memorizzazione dei dati nelle variabili e nei
Dettaglidott. Sabrina Senatore
dott. Sabrina Senatore Dipartimento di Informatica Riepilogo strutture 1 Sintassi della dichiarazione: typedef struct nome_tipo { Dichiarazione dei campi nome_tipo; typedef struct point{ int x; int y;
DettagliI/O Avanzato in C: scheda riassuntiva
Funzione sscanf r = sscanf(str, "formato", &variabili ) ; str Stringa da cui acquisire i dati "formato" Sequenza dei campi da leggere ("%d", "%s",... ) &variabili Variabili nelle quali depositare i valori
DettagliTitolo presentazione INFORMATICA. sottotitolo A.A Milano, XX mese 20XX Laboratorio n 6 Ing. Gian Enrico Conti Dott.
Titolo presentazione INFORMATICA A sottotitolo A.A. 2017-18 Milano, XX mese 20XX Laboratorio n 6 Ing. Gian Enrico Conti Dott. Michele Zanella Info Logistiche (cont d) Calendario laboratori Data Orario
DettagliSoluzioni seconda prova intermedia del 30 gennaio 2006 temi 1 e 2. Siano date le seguenti definizioni di costanti e tipi in linguaggio C:
Fondamenti Informatica B Soluzioni seconda prova intermedia del 30 gennaio 2006 temi 1 e 2 Esercizio 1 tema 1 Siano date le seguenti definizioni di costanti e tipi in linguaggio C: #define MAX_LENGTH 40
DettagliProf. G. Ascia. Allocazione dinamica della memoria (2)
Allocazione dinamica della memoria (2) 1 Allocazione dinamica e funzioni Con il seguente programma si vorrebbe allocare dinamicamente un vettore all interno di una funzione (leggi_vettore) #include
DettagliLe strutture /3. Riprendiamo ora la struttura definita alcune lezioni fa e completiamo il set di funzioni che servono per gestire un elenco di libri.
Le strutture /3 Riprendiamo ora la struttura definita alcune lezioni fa e completiamo il set di funzioni che servono per gestire un elenco di libri. typedef struct {char titolo[200]; char autore[100];
DettagliEsercizi Array. Parte 7. Domenico Daniele Bloisi. Corso di Fondamenti di Informatica Ingegneria delle Comunicazioni BCOR Ingegneria Elettronica BELR
Corso di Fondamenti di Informatica Ingegneria delle Comunicazioni BCOR Ingegneria Elettronica BELR Domenico Daniele Bloisi Docenti Parte I prof. Silvio Salza salza@dis.uniroma1.it http://www.dis.uniroma1.it/~salza/fondamenti.htm
DettagliEsercitazione 6. Array
Esercitazione 6 Array Arrays Array (o tabella o vettore): è una variabile strutturata in cui è possibile memorizzare un numero fissato di valori tutti dello stesso tipo. Esempio int a[6]; /* dichiarazione
DettagliNon ci sono vincoli sul tipo degli elementi di un vettore Possiamo dunque avere anche vettori di
ARRAY DI PUNTATORI Non ci sono vincoli sul tipo degli elementi di un vettore Possiamo dunque avere anche vettori di puntatori Ad esempio: char * stringhe[4]; definisce un vettore di 4 puntatori a carattere
DettagliEsercitazioni di Fondamenti di Informatica - Lez. 7 20/11/2018
Esercitazioni di Fondamenti di Informatica - Lez. 7 0/11/018 Esercizi sull allocazione dinamica della memoria in C 1. Cosa stampa il seguente programma? 1 #d e f i n e MAXLENGTH 0 4 typedef struct { char
DettagliConsideriamo un vettore allocato dinamicamente
Libreria per per la la gestione/manipolazione dei dei vettori Consideriamo un vettore allocato dinamicamente int * v; v = (int *) malloc (n * sizeof (int) ); Conversione di tipo da void * a int * Numero
DettagliAllocazione Dinamica. Allocazione Statica. malloc() La funzione malloc()
Allocazione Statica Finora abbiamo visto che le variabili sono sempre definite staticamente. Questo è un limite perché la loro esistenza deve essere prevista e dichiarata a priori. In particolare per variabili
DettagliLezione X Definizione di vettori a run-time
Programmazione e Laboratorio di Programmazione Lezione X Definizione di vettori a run-time Programmazione e Laboratorio di Programmazione: Definizione di vettori a run-time 1 Definizione statica di vettori
DettagliLinguaggio C - Puntatori
Puntatori: I puntatori sono uno dei costrutti più potenti del linguaggio C; permettono ai programmi di realizzare il passaggio per riferimento, di passare funzioni alle funzioni, di accedere direttamente
DettagliStringhe in C. Luca Abeni. Informatica Luca Abeni 1 / 10
Stringhe in C Luca Abeni Informatica Luca Abeni 1 / 10 Stringhe in C Stringhe: tipo di dato strutturato Sequenze di caratteri Linguaggio C: progettato per la semplicità No supporto nativo per le stringhe
DettagliDefinizione Allocazione e deallocazione di variabili Allocazione e deallocazione di vettori
Università degli Studi di Cagliari Corso di Laurea in Ingegneria Biomedica (Industriale), Chimica, Meccanica, Elettrica FONDAMENTI DI INFORMATICA 1 http://www.diee.unica.it/~marcialis/fi1 A.A. 2010/2011
DettagliEsercitazione Matrici e Struct
Esercitazione Matrici e Struct Informatica B, AA 2017/2018 Luca Cassano 19 Ottobre 2017 luca.cassano@polimi.it Breve riassunto della puntata precedente Breve riassunto della puntata precedente Matrici
DettagliLaboratorio di Elementi di Architetture e Sistemi Operativi Soluzioni degli Esercizi del 9 Maggio 2012
Laboratorio di Elementi di Architetture e Sistemi Operativi Soluzioni degli Esercizi del 9 Maggio 2012 Esercizio 1. Scrivere un programma che: 1. legga a da tastiera un vettore di float di dimensione non
DettagliJAVA. import java.util.*; #include <stdio.h> public static class test { int variable; private int variable; int main (int argc, char *argv[]) {
JAVA C import javautil*; public static class test { private int variable; public void main (String[] args) { variable = 0; Systemoutprintln( Variable is: + variable); #include int variable; int
Dettaglisoldi soldi, int, char, float char, int, float, double char: int float: double: float int char signed unsigned short int long int double Unità di Elaborazione (CPU) unsigned int Pippo long int Pluto
DettagliStringhe in C. Nicu Sebe. Informatica Nicu Sebe 1 / 14
Stringhe in C Nicu Sebe Informatica Nicu Sebe 1 / 14 Stringhe in C Stringhe: tipo di dato strutturato Sequenze di caratteri Linguaggio C: progettato per la semplicità No supporto nativo per le stringhe
DettagliEsercizio 1: funzione con valore di ritorno di tipo puntatore
Esercitazione Fondamenti di Informatica B Corso di Laurea in Ingegneria Meccanica 7 Esercitazione: 14 dicembre 2005 Esercizi su ricorsione, manipolazione stringhe, strutture dinamiche Problema: Esercizio
DettagliRecord di Attivazione e Parametri Formali di una Funzione. Prof.Ing.S.Cavalieri
e di una Funzione Prof.Ing.S.Cavalieri Area di Memoria Stack Area Programma Area Statica Area Dati Heap Stack Valore di Ritorno (se presente) : #include int x; main() void R (int a) { x=a; void
Dettagli- Dispensa IV - PROGRAMMAZIONE C (Parte II)
Elementi di Informatica e Programmazione - Dispensa IV - PROGRAMMAZIONE C (Parte II) Alessandro Saetti (email: alessandro.saetti@unibs.it) Università degli Studi di Brescia A.A. 2016/2017 1 Vettori e Matrici
DettagliEsercizio (o esempio?)
Esercizio (o esempio?) programma che legge un intero n e n double; li memorizza in un array dinamico esatto calcola e stampa minimo, massimo e media dei double #include 1) Lettura e memorizzazione
DettagliIl linguaggio C Puntatori
Il linguaggio C Puntatori Moreno Marzolla Dipartimento di Informatica Scienza e Ingegneria (DISI) Università di Bologna http://www.moreno.marzolla.name/ Linguaggio C - puntatori 2 Ringraziamenti Questi
Dettagliprogrammazione distribuita Introduzione Introduzione alla programmazione distribuita
Reti Informatiche Introduzione alla programmazione distribuita Introduzione Richiami di Programmazione C Differenze principali C/C++ 2 1 Definizioni di variabili Le variabili possono essere definite solo
DettagliC: panoramica. Violetta Lonati
C: panoramica Violetta Lonati Università degli studi di Milano Dipartimento di Scienze dell Informazione Laboratorio di algoritmi e strutture dati Corso di laurea in Informatica AA 2009/2010 Violetta Lonati
DettagliGestione dei files. Prof. Francesco Accarino IIS Altiero Spinelli Sesto San Giovanni Via Leopardi 132
Gestione dei files Prof. Francesco Accarino IIS Altiero Spinelli Sesto San Giovanni Via Leopardi 132 Struttura del disco fisso Un disco fisso è composto da una serie di piatti sovrapposti Ogni piatto è
DettagliFondamenti di Informatica 2
Fondamenti di Informatica 2 Soluzione della prova scritta del 31 Gennaio 2006 Esercizio 1 (4 punti) Elencare i tipi di dato predefiniti del linguaggio C, precisandone il dominio e le operazioni principali
Dettagli#include <stdio.h> #include <stdlib.h> //necessaria per la malloc #include <string.h> // costante #define MAX_L 30
/* Dopo aver definito una lista in grado di contenere i dati di alcune persone (nome, genere e altezza in metri), scrivere un programma che consenta di verificare che inizialmente la lista sia vuota e
Dettagliint, char, float.. int, char, float.. - char, int, float, double char: int float: double: float int char signed unsigned short int long int double int Pippo; unsigned int Pippo; long int Pippo; long int
DettagliFile di testo e file binari Soluzione 1 (2)
File di testo e file binari Soluzione 1 (2) printf("cifrazione del file: "); scanf("%s",nome); // Controllo che il file esista. while((fs=fopen(nome,"r"))==null) { printf("errore nel nome del file, file
Dettaglisoldi soldi, int, char, float.. int, char, float.. - char, int, float, double char: int float: double: float int char signed unsigned short int long int double int Pippo; unsigned int Pippo; long int
DettagliSTRUCT - ESERCIZIO 1
STRUCT - ESERCIZIO 1 Si vuole realizzare un programma di utilità matematica per gestire i numeri complessi. In particolare: 3. Progettare una opportuna struttura per la loro rappresentazione (in coordinate
DettagliCaratteri e stringhe
Caratteri e stringhe Caratteri Dato che un computer può memorizzare esclusivamente sequenze di bit, per memorizzare un carattere (e quindi testi) è necessario stabilire una convenzione che associa a un
DettagliAstrazione sui Dati Vettori di variabili
Elementi di Informatica e Programmazione Ingegneria Informatica Ingegneria dell'automazione Industriale Ingegneria Elettronica e delle Telecomunicazioni Alessandro Saetti (email: alessandro.saetti@unibs.it)
DettagliEsercizio 1: calcolo insieme intersezione
Esercitazione Fondamenti di Informatica B Corso di Laurea in Ingegneria Meccanica 3 Esercitazione: 19 ottobre 2005 Esercizi su array e matrici Esercizio 1: calcolo insieme intersezione Problema: *******************************************************************
DettagliLezione 11: Liste a Puntatori e Input/Output
Lezione 11: Liste a Puntatori e Input/Output Vittorio Scarano Laboratorio di Informatica I Corso di Laurea in Informatica Università degli Studi di Salerno Struttura della lezione Richiamo: strutture (struct)
DettagliFondamenti di Informatica 2
Fondamenti di Informatica 2 della prova scritta del 25 Luglio 2006 Esercizio 1 (4 punti) Date le seguenti variabili int A[] = 2,3,7,-2,5,-8,-4; int N = 7; int i; Scrivere la porzione di codice che sostituisca
DettagliINFORMATICA. Puntatori e memoria dinamica. Puntatori. Puntatori. Puntatori: esempio. I puntatori sono variabili che contengono indirizzi di memoria.
INFORMATICA Puntatori I puntatori sono variabili che contengono indirizzi di memoria. Sono specificati tramite l operatore unario * specificato accanto al nome della variabile. Sintassi: *
DettagliStrutture dati. Operatori di incremento e decremento. Strutture di dati. Strutture di dati. ++ e -- Esempi. Vettori e matrici.
Operatori di incremento e decremento ++ e -- Esempi y=x++ il contenuto della variabile x viene inizialmente usata per l assegnazione y, e solo dopo incrementata y=--x il contenuto della variabile x viene
DettagliLezione 7: Funzioni e gestione dei File
Lezione 7: Funzioni e gestione dei File Laboratorio di Elementi di Architettura e Sistemi Operativi 18 Aprile 2012 Le funzioni Funzioni Un programma C consiste di una o più funzioni Almeno main() Funzionamento
DettagliFondamenti di Informatica 2
Fondamenti di Informatica 2 della prova scritta del 14 Febbraio 2006 Esercizio 1 (4 punti) Formulare la seguente istruzione del linguaggio C utilizzando il costrutto while: for(i=0,j=n-1; i
DettagliARRAY DI PUNTATORI. ARRAY DI PUNTATORI Non ci sono vincoli sul tipo degli elementi di un vettore Possiamo dunque avere anche vettori di puntatori
ARRAY DI PUNTATORI Non ci sono vincoli sul tipo degli elementi di un vettore Possiamo dunque avere anche vettori di puntatori Ad esempio: char * stringhe[4]; definisce un vettore di 4 puntatori a carattere
DettagliSistemi operativi A, Unix+C, 26/09/2017. Nome: Cognome: Matricola:
Sistemi operativi A, Unix+C, 26/09/2017 Nome: Cognome: Matricola: ESERCIZIO RELATIVO ALLA PARTE DI UNIX (3 punti) Si scriva lo pseudo-codice necessario a generare un albero binario di processi di profondità
DettagliAppunti tratti dal videocorso on-line di Algoritmi e Programmazione Avanzata By ALeXio
Appunti tratti dal videocorso on-line di Algoritmi e Programmazione Avanzata By ALeXio 1-La memoria dinamica La scrittura di un programma (indipendentemente dal linguaggio adottato) deve sempre tener conto
DettagliFondamenti di Informatica e Laboratorio T-AB Ingegneria Elettronica e Telecomunicazioni e Ingegneria dell Automazione a.a. 2009/2010.
Fondamenti di Informatica e Laboratorio T-AB Ingegneria Elettronica e Telecomunicazioni e Ingegneria dell Automazione a.a. 2009/2010 Errori comuni 1 Versione Corretta #include int main(void)
DettagliPolitecnico di Milano. Strutture dati dinamiche
Politecnico di Milano Strutture dati dinamiche Strutture dati statiche e dinamiche In C le dimensioni di ogni dato sono note prima dell esecuzione Sarebbe utile avere contenitori la cui dimensione varia
DettagliCorso di Informatica 1 (IN110) Tutorato n. 4
Corso di Informatica 1 (IN110) Tutorato n. 4 Marco Liverani Esercizio n. 1 Letto in input un array di n numeri interi ed un intero k > 1, eliminare dall array tutti i multipli di k, spostando a sinistra
DettagliGestione dinamica della memoria
Programmazione M-Z Ingegneria e Scienze Informatiche - Cesena A.A. 2016-2017 Gestione dinamica della memoria Pietro Di Lena - pietro.dilena@unibo.it A pessimistic programmer sees the array as half empty.
Dettaglichar *s; s = (char *) malloc(5*sizeof(char)); scanf( %s, s); Stringhe
char *s; s = (char *) malloc(5*sizeof(char)); scanf( %s, s); Stringhe Stringhe s char *s; s = (char *) malloc(5*sizeof(char)); scanf( %s, s); c i a o \0 Scrivere un programma che legga da input un array
DettagliStringhe. Unità 8. Corso di Laboratorio di Informatica Ingegneria Clinica BCLR. Domenico Daniele Bloisi
Corso di Ingegneria Clinica BCLR Domenico Daniele Bloisi Docente Ing. Domenico Daniele Bloisi, PhD Ricercatore Dipartimento di Ingegneria Informatica, Automatica e Gestionale Antonio Ruberti Via Ariosto
DettagliLezione 19 e Allocazione dinamica della memoria - Direttive al preprocessore - Libreria standard - Gestione delle stringhe
Lezione 19 e 20 - Allocazione dinamica della memoria - Direttive al preprocessore - Libreria standard - Gestione delle stringhe Valentina Ciriani (2005-2008) Laboratorio di programmazione Valentina Ciriani
DettagliIntroduzione al C Lez. 4
Introduzione al C Lez. 4 Allocazione Dinamica della memoria http://www.di.unipi.it/~rossano/algo1/lez4.pdf Allocazione dinamica memoria In C la memoria può essere anche gestita in modo dinamico, attraverso
DettagliIntroduzione al C Lez. 4. Allocazione Dinamica della memoria
Introduzione al C Lez. 4 Allocazione Dinamica della memoria Allocazione dinamica memoria In C la memoria può essere anche gestita in modo dinamico, attraverso l allocazione esplicita di blocchi di memoria
Dettagli