Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Roborock Qrevo Curv 2 Flow: ora lava con un rullo
Roborock Qrevo Curv 2 Flow: ora lava con un rullo
Qrevo Curv 2 Flow è l'ultima novità di casa Roborock per la pulizia di casa: un robot completo, forte di un sistema di lavaggio dei pavimenti basato su rullo che si estende a seguire il profilo delle pareti abbinato ad un potente motore di aspirazione con doppia spazzola laterale
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite
Abbiamo guidato per diversi giorni la Alpine A290, la prima elettrica del nuovo corso della marca. Non è solo una Renault 5 sotto steroidi, ha una sua identità e vuole farsi guidare
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile
Abbiamo provato a fondo il nuovo Magic 8 Lite di HONOR, e per farlo siamo volati fino a Marrakech , dove abbiamo testato la resistenza di questo smartphone in ogni condizione possibile ed immaginabile. Il risultato? Uno smartphone praticamente indistruttibile e con un'autonomia davvero ottima. Ma c'è molto altro da sapere su Magic 8 Lite, ve lo raccontiamo in questa recensione completa.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 30-04-2014, 12:32   #1
BigMeister
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;
............
............
}
Grazie a tutti!

Ultima modifica di BigMeister : 30-04-2014 alle 12:35.
BigMeister è offline   Rispondi citando il messaggio o parte di esso
Old 30-04-2014, 12:53   #2
british
Member
 
L'Avatar di british
 
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
british è offline   Rispondi citando il messaggio o parte di esso
Old 30-04-2014, 12:59   #3
BigMeister
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
BigMeister è offline   Rispondi citando il messaggio o parte di esso
Old 30-04-2014, 13:56   #4
BigMeister
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.
BigMeister è offline   Rispondi citando il messaggio o parte di esso
Old 30-04-2014, 14:03   #5
vendettaaaaa
Senior Member
 
L'Avatar di vendettaaaaa
 
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;
anzichè
Codice:
int a = 0;
mi basta anteporre un bel
Codice:
typedef int intero;
E da quel momento quando il compilatore legge "intero" gli sostituisce "int", che è il tipo di variabile che lui conosce e usa internamente. Alias vuol dire proprio "sinonimo".

Nel primo dei tuoi esempi, dai alla struct elem il sinonimo elem_t, per poter scrivere
Codice:
elem_t a;
anzichè
Codice:
elem a;
Poi definisci un altro sinonimo, ELEMENTO, per intendere elem_t*, cioè ELEMENTO è un puntatore ad una variabile di tipo elem_t.
Dato che questo alias è alla fine un tipo, ELEMENTO è il tipo della variabile elemento.
Se scrivo
Codice:
typedef int intero;
intero abc;
ELEMENTO sta ad intero come elem_t sta ad int (sono tipi di variabile), ed elemento sta ad abc, perchè sono variabili (non tipi).

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.
vendettaaaaa è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Roborock Qrevo Curv 2 Flow: ora lava con un rullo Roborock Qrevo Curv 2 Flow: ora lava con un rull...
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite Alpine A290 alla prova: un'auto bella che ti fa ...
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile Recensione HONOR Magic 8 Lite: lo smartphone ind...
Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora Sony WF-1000X M6: le cuffie in-ear di riferiment...
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI Snowflake porta l'IA dove sono i dati, anche gra...
Arianespace potrebbe lanciare il primo r...
Google Pixel 10a disponibile al prezzo m...
Microsoft Copilot nei guai: email riserv...
AOC a 399€ su Amazon: QD-OLED 240 Hz e 0...
La Cina ha recuperato dal mare il primo ...
Boeing CST-100 Starliner: la NASA rende ...
hiop e TaDa uniscono le forze per trasfo...
Thermal Grizzly mostra il Ryzen 7 9850X3...
AMD Ryzen 'Olympic Ridge' Zen 6 per desk...
Donald Trump renderà pubbliche in...
Prezzo mai visto da mesi: ECOVACS DEEBOT...
Non solo S26, Samsung sta per lanciare a...
Windows 11 avrà a breve uno Speed...
Ask Intel: l'assistente IA che ti aiuta ...
Nasce Freedom.gov: il portale USA per ag...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 05:45.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Served by www3v