Retourner des références est utile lorsque l'on souhaite utiliser une fonction pour déterminer à quelle variable une référence devrait être liée. Il ne faut pas utiliser le retour par référence pour améliorer les performances, le moteur est suffisamment robuste pour optimiser cela en interne. Il convient de ne retourner des références que lorsqu'il y a de bonnes raisons techniques de le faire. Pour retourner des références, utiliser cette syntaxe :
<?php
class Foo
{
public $value = 42;
public function &getValue()
{
return $this->value;
}
}
$obj = new Foo();
$myValue = &$obj->getValue(); // $myValue est une référence de $obj->value, qui vaut 42.
$obj->value = 2;
echo $myValue; // affiche la nouvelle valeur de $obj->value, i.e. 2.
?>Note: Contrairement au passage de paramètre, ici, il faut utiliser
&aux deux endroits, à la fois pour indiquer le retour par référence (pas par copie), et pour indiquer l'assignation aussi par référence (pas par copie non plus) pour la variable $myValue.
Note: Tenter de retourner une référence depuis une fonction avec la syntaxe :
return ($this->value);, ne fonctionnera pas comme attendu, et retournera le résultat de l'expression, et pas de la variable, par référence. Seules des variables peuvent être retournées par référence depuis une fonction - et rien d'autre.
Pour utiliser la référence retournée, il faut utiliser l'affectation par référence :
<?php
function &collector()
{
static $collection = array();
return $collection;
}
$collection = &collector();
// Désormais, la variable $collection est une variable par référence qui référence le tableau static à l’intérieur de la fonction
$collection[] = 'foo';
print_r(collector());
// Array
// (
// [0] => foo
// )
?>Pour passer la référence retournée à une autre fonction attendant une référence, il est possible d'utiliser la syntaxe suivante :Note: Si l'affectation est faite sans le symbole
&, par exemple$collection = collector();, la variable $collection recevra une copie de la valeur, et non la référence retournée par la fonction.
<?php
function &collector()
{
static $collection = array();
return $collection;
}
array_push(collector(), 'foo');
?>Note: Il est à noter que
array_push(&collector(), 'foo');ne fonctionnera pas, et résultera en une erreur fatale.