Conversione di tipoIn informatica, in particolare nella programmazione, la conversione di tipo (detta impropriamente casting, o typecasting, dal nome di uno dei modi in cui essa si manifesta) è l'operazione con cui si converte una variabile da un tipo di dato a un altro: questo passaggio è effettuato per avvantaggiarsi di alcune caratteristiche delle gerarchie dei tipi. Per esempio, i valori di un intervallo limitato (come quello degli interi) possono essere immagazzinati in piccole quantità di memoria, per poi essere convertiti in un formato diverso che potenzialmente permette nuove operazioni, come la divisione con varie cifre decimali di precisione. Nei linguaggi di programmazione orientati agli oggetti, la conversione di tipo permette ai programmi di trattare gli oggetti come se fossero di un tipo antenato, ad esempio per semplificare l'interazione con questi oggetti. Tipi di conversioneEsistono due tipi di conversione di tipo: implicita ed esplicita. Il termine utilizzato per riferirsi alla conversione implicita è coercion (it.: coercizione), mentre il metodo più comune di conversione esplicita è chiamato casting (sostantivo che, a volte, viene impropriamente usato per indicare il significato generale di conversione). La conversione esplicita può essere eseguita anche con delle funzioni di conversione definite separatamente, come i costruttori sovraccarichi. Conversione di tipo implicitaLa conversione implicita di tipo, conosciuta anche con il nome inglese coercion, è svolta in maniera automatica dal compilatore. Alcuni linguaggi di programmazione, addirittura, richiedono che questa funzionalità sia implementata nel compilatore. In un'espressione di tipo misto, a runtime, i dati di uno o più sottotipi possono essere convertiti in tipi più generici in maniera che l'espressione sia valutata correttamente. Per esempio, il codice C che segue è valido: double d; long l; int i; if (d > i) d = i; if (i > l) l = i; if (d == l) d *= 2; Nonostante Conversione di tipo esplicitaUn esempio di casting in un frammento di codice C: int arrotonda(float value){ return (int)(value + 0.5); } Il codice definisce, a titolo puramente esemplificativo, una semplice funzione che implementa l'operazione di arrotondamento di un numero decimale positivo. Poiché il valore dell'espressione int a = 5; int b = 3; float c, d; c = a / b; /* c adesso contiene il valore 1.0 */ d = (float)a / b; /* d assume il valore atteso: 1.6666666 */ Nonostante Esistono vari tipi di conversione esplicita:
Ogni linguaggio di programmazione ha le proprie regole per le conversioni di tipo: in generale, essa è ammessa per oggetti e tipi fondamentali. Voci correlate |
Portal di Ensiklopedia Dunia