|
|||||||
|
|
|
![]() |
|
|
Strumenti |
|
|
#1 |
|
Junior Member
Iscritto dal: Dec 2013
Messaggi: 20
|
Typedef Struct
Buongiorno ragazzi, ho una domanda molto veloce, qual'è la differenza fra questo tipo di dichiarazione:
Codice:
typedef struct elem
{
char carattere;
char *stringa;
struct elem *succ;
}elem_t;
typedef elem_t *ELEMENTO;
int main(){
........
........
ELEMENTO elemento = NULL;
........
........
}
e invece questa? Codice:
typedef struct elem
{
char carattere;
char *stringa;
struct elem *succ;
}elem_t;
int main(){
............
............
elem_t *ELEMENTO;
ELEMENTO = NULL;
............
............
}
Ultima modifica di BigMeister : 30-04-2014 alle 12:35. |
|
|
|
|
|
#2 |
|
Member
Iscritto dal: Sep 2008
Città: Milano
Messaggi: 126
|
Nel primo esempio:
elem_t è un tipo "alias" il cui tipo corrispondente è "struct elem" ELEMENTO è un tipo "alias" il cui tipo corrispondente è "puntatore a un elem_t" elemento è una variabile, allocata sullo stack, il cui tipo è ELEMENTO e che punta a NULL Nel secondo esempio: elem_t è un tipo "alias" il cui tipo corrispondente è "struct elem" ELEMENTO è una variabile, allocata sullo stack, il cui tipo è "puntatore a un elem_t" e che punta a NULL |
|
|
|
|
|
#3 |
|
Junior Member
Iscritto dal: Dec 2013
Messaggi: 20
|
Devo ammettere che faccio ancora fatica a capire. Ti faccio questo esempio almeno capisci perchè non capisco.
Ho usato entrambe le due dichiarazioni per creare una lista: la prima funziona egregiamente, i valori sia nella stringa che nella variabile carattere sono correttamente inseriti. la seconda funziona in parte, cioè inserisce gli elementi dentro la variabile carattere correttamente ma la stringa di qualsiasi elemento è uguale per tutti, insomma come se la stringa puntasse alla stessa cella di memoria di tutte le stringhe negli altri elementi creati. Alla luce di ciò, come può questo ricollegarsi al tuo discorso? EDIT: Cioè le due cose sembrano fare la stessa identica cosa fondamentalmente, non capisco perchè però quella stringa si comporta in maniera differente nei due casi! Ultima modifica di BigMeister : 30-04-2014 alle 13:09. Motivo: Chiarimenti |
|
|
|
|
|
#4 |
|
Junior Member
Iscritto dal: Dec 2013
Messaggi: 20
|
Problema risolto. La stringa va allocata dinamicamente correttamente altrimenti gli elementi non vengono acquisiti nel secondo caso, o meglio, l'acquisizione dell'ultimo elemento vale per tutti gli elementi della lista.
Grazie lo stesso della dritta perchè ho compreso ora le differenza fra le diverse dichiarazioni e in generale la typedef. |
|
|
|
|
|
#5 |
|
Senior Member
Iscritto dal: Jan 2012
Messaggi: 1267
|
La sintassi del typedef è:
typedef NomeDelTipoACuiVuoiCambiareNome NuovoNomeCheVuoiDareAlTipo. n.b.: NomeDelTipoACuiVuoiCambiareNome può essere un tipo creato in loco, come hai fatto tu dando alla struct elem, che definisci in loco, il sinonimo elem_t. Quindi, se io voglio scrivere codice tipo: Codice:
intero a = 0; Codice:
int a = 0; Codice:
typedef int intero; Nel primo dei tuoi esempi, dai alla struct elem il sinonimo elem_t, per poter scrivere Codice:
elem_t a; Codice:
elem a; Dato che questo alias è alla fine un tipo, ELEMENTO è il tipo della variabile elemento. Se scrivo Codice:
typedef int intero; intero abc; Nel secondo esempio, tu crei una variabile di tipo elem_t*, chiamata ELEMENTO. ELEMENTO quindi non è più un tipo, ma una variabile. La differenza è quindi abissale (tipo vs variabile), ma sembra sottile perchè il tipo di elemento (1° esempio) ed ELEMENTO (2° esempio) è lo stesso: queste due variabili sono di tipo elem_t*, cioè sono due puntatori ad una struct elem. Se ci fai vedere il codice dove usi le liste poi è meglio che raccontarlo a parole. |
|
|
|
|
| Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 12:18.



















