Distruttore (informatica): differenze tra le versioni

Contenuto cancellato Contenuto aggiunto
m Linguaggi garbage collected: Eliminato una d cacofonica
 
(6 versioni intermedie di 4 utenti non mostrate)
Riga 5:
 
== Uso ==
Nella creazione del codice di un distruttore occorre agire con particolare attenzione, in quanto per evitare fenomeni di ''[[memory leak]]'' si deve essere certi che tutte le [[strutture dati]] liberino correttamente la memoria da loro utilizzata compresa quella eventualmente utilizzata da altre strutture annidate al loro interno.
 
Il distruttore, a differenza del [[costruttore (informatica)|costruttore]], non può accettare nessun tipo di parametro, perché se non chiamato esplicitamente, sarà il compilatore a inserire a fine programma la chiamata al distruttore. Per questo motivo, per ogni classe può esserci un solo distruttore, rendendo impossibile l'''[[overloading]]''.
 
ATTENZIONE: nonNon è obbligatorio che un distruttore sia dichiarato <code>public!.</code> L'esempio:
<syntaxhighlight lang="cpp" line="1">
L'esempio:
<source lang="cpp">
class A {int i;
~A() {}
Riga 22 ⟶ 21:
// A b(1); <----- non ammesso perché il distruttore è privato (error C2248: 'A::~A' : cannot access private member declared in class 'A')
}
</syntaxhighlight>
</source>
 
compila perfettamente ma impedisce che un oggetto di classe A venga istanziato sullo stack ma consente che venga istaziatoistanziato sullo ''[[Heap (gestione della memoria)|heap]]''. È ovvio tuttavia che un metodo di distruzione debba essere fornito all'utente il quale, a questo punto, può accettare anche dei parametri e tornare dei valori.
Esempio:
<sourcesyntaxhighlight lang="cpp" line="1">
class A {int i;
static int count;
Riga 41 ⟶ 40:
b = A::Delete (a); // b=0
}
</syntaxhighlight>
</source>
 
=== Linguaggi ''garbage collected'' ===
Nei linguaggi che mettono a disposizione un ''[[Garbage collection|garbage collector]]'', il distruttore è spesso inutile in quanto le risorse occupate da un oggetto vengono automaticamente liberate nel momento in cui non c'è più nessun riferimento all'oggetto stesso. In questi linguaggi è generalmente possibile utilizzare o definire ugualmente appositi metodi per ottenere il medesimo effetto, nei casi in cui si desideri disattivare il garbage collector, in quanto per alcuni task critici potrebbe risultare troppo inefficiente. Esempio di linguaggi di programmazione fra i più conosciuti ada utilizzare il meccanismo della ''garbage collection'' sono [[Java (linguaggio di programmazione)|Java]] e la versione 2 di [[Objective-C]].
 
== Linguaggi di programmazione ==
=== [[C++]] ===
 
<source lang="cpp">
In C++ l'implementazione esplicita del distruttore è solitamente necessaria nell'implementazione di classi che gestiscono risorse. In accordo alla [[regola del tre (C++)|regola del tre]], solitamente l'implementazione del distruttore è accompagnata dall'implementazione di un [[costruttore di copia]] e di un [[operatore di assegnamento]].
 
<syntaxhighlight lang="cpp" line="1">
class Point
{
Riga 59 ⟶ 61:
int y;
}
</syntaxhighlight>
</source>
 
=== [[C#]] ===
'''Questo linguaggio possiede il [[''garbage collection]]'' rendendo poco usati i distruttori'''
<sourcesyntaxhighlight lang="csharp" line="1">
public class Punto
{
Riga 72 ⟶ 74:
}
}
</syntaxhighlight>
</source>
 
=== [[PHP]] ===
==== [[PHP]] 4 ====
Nella versione 4 (e precedenti) di PHP non esisteva il distruttore. Era presente una semplice gestione degli oggetti con l'uso dei [[Costruttore (informatica)|costruttori]].
 
==== [[PHP]] 5 ====
Nella versione 5 il nome della funzione deve essere ''<code>__destructor''()</code>.
<sourcesyntaxhighlight lang="php">
class Point
{
Riga 90 ⟶ 92:
}
}
</syntaxhighlight>
</source>
 
== Voci correlate ==
*[[Costruttore (informatica)|Costruttore]]
*[[Programmazione orientata agli oggetti]]
 
== Collegamenti esterni ==
* {{FOLDOC|destructor|destructor}}
 
{{portale|informatica}}
Riga 100 ⟶ 105:
[[Categoria:Programmazione]]
[[Categoria:Programmazione orientata agli oggetti]]
 
[[bg:Деструктор (програмиране)]]