Classi e Oggetti
PHP Manual

Clonazione di oggetti

Creare una copia di un oggetto con tutte le proprietà replicate non è sempre il comportamento desiderato. Un esempio della necessità di costruttori per la copia, è che quando si ha un oggetto che rappresenta una finestra GTK e l'oggetto detiene le risorse di questa finestra GTK, quando si crea un duplicato si può voler creare una nuova finestra con le stesse proprietà e fare in modo che il nuovo oggetto detenga le risorse della nuova finestra. Un ulteriore esempio è il caso in cui un oggetto ha un riferimento ad un altro oggetto che utilizza e quando si replica il l'oggetto padre si vuole creare una nuova istanza di questo altro oggetto in modo che la replica ne abbia una propria copia separata dall'originale.

La copia di un oggetto viene creata utilizzando la parola chiave clone (che chiama se possibile il metodo __clone() dell'oggetto). Il metodo __clone() di un oggetto non può essere invocato direttamente.

$copy_of_object = clone $object;

Quando un oggetto viene clonato, PHP 5 esegue una copia superficiale di tutte le proprietà dell'oggetto. Ogni proprietà che sia un riferimento ad altre variabili rimarrà un riferimento.

void __clone ( void )

Completata la clonazione, se esiste un metodo __clone(), viene chiamato il metodo __clone() dell'oggetto appena creato per consentire l'aggiornamento di tutte le proprietà che necessitano di essere modificate.

Example #1 Clonazione di un oggetto

<?php
class SubObject
{
    static 
$instances 0;
    public 
$instance;

    public function 
__construct() {
        
$this->instance = ++self::$instances;
    }

    public function 
__clone() {
        
$this->instance = ++self::$instances;
    }
}

class 
MyCloneable
{
    public 
$object1;
    public 
$object2;

    function 
__clone()
    {
        
// forza la copia di $this->object1, che altrimenti
        // punterebbe alla stessa istanza.
        
$this->object1 = clone $this->object1;
    }
}

$obj = new MyCloneable();

$obj->object1 = new SubObject();
$obj->object2 = new SubObject();

$obj2 = clone $obj;


print(
"Oggetto originale:\n");
print_r($obj);

print(
"Oggetto clonato:\n");
print_r($obj2);

?>

Il precedente esempio visualizzerà:

Oggetto orginale:
MyCloneable Object
(
    [object1] => SubObject Object
        (
            [instance] => 1
        )

    [object2] => SubObject Object
        (
            [instance] => 2
        )

)
Oggetto clonato:
MyCloneable Object
(
    [object1] => SubObject Object
        (
            [instance] => 3
        )

    [object2] => SubObject Object
        (
            [instance] => 2
        )

)

Classi e Oggetti
PHP Manual