引用:不同的名字访问同一个变量内容。比如,定义了一个$a=1,再定义一个$a的引用:$b=&$a,那么$a,$b指向的是同一个变量内容,如果$a=2,$b也变成了2。
如果对一个未定义的变量进行引用赋值、引用参数传递或引用返回,则会自动创建该变量,并且值是null。
栗子:
foo($a); // $a 被自动创建,并且$a=null
$b = array();
foo($b['b']);
var_dump(array_key_exists('b', $b)); //$b[‘b’]=null,输出true
$c = new StdClass;
foo($c->d);
var_dump(property_exists($c, 'd')); // $c->d=null,
如果在一个函数内部给一个声明为 global 的变量赋于一个引用,该引用只在函数内部可见,就是说改变这个引用的值不并影响全局变量的值,要想改变全局变量,可以通过使用 $GLOBALS 数组。
栗子:
$var1 = "Example variable";
$var2 = "";
function global_references($use_globals)
{
global $var1, $var2;
if (!$use_globals) {
$var2 =& $var1; // 因为这个引用只是在这个函数内部可见的,所以并不改变全局变量$var2的值
} else {
$GLOBALS["var2"] =& $var1; // 这时候就改变了全局变量的值
}
}
global_references(false);
echo "var2 is set to '$var2'\n"; // 输出var2 is set to ''
global_references(true);
echo "var2 is set to '$var2'\n"; //输出 var2 is set to 'Example variable'
global $var,其实是 $var = & $GLOBALS['var'] 的简写,所以把其他引用赋给$var只是改变了当前作用域$var的值,并不改变全局变量的值。
如果在 foreach 语句中给一个具有引用的变量赋值,被引用的对象也被改变。
栗子:
$ref = 0;
$row =& $ref;
foreach (array(1, 2, 3) as $row) {
}
echo $ref; // 输出3,因为最后一次把3赋给了$ref的引用$row
引用指向的是变量的内容,和变量无关,如果变量的值被指向了其他地方,它之前的引用不会变。
栗子:
$a = 1;
$c = 2;
$b =& $a;
$a =& $c; // 虽然$a现在指向值为2的变量,但是$b还是指向$a之前的值
echo $a, " ", $b; //输出结果 2 1
任何其它表达式都不能通过引用传递,意思是,如果一个函数的参数被定义为一个引用,那么调用函数时传的实参必须是变量,不能是任何表达式。
因为引用只是一个变量名和变量内容之间进行了一次绑定,因此把一个引用unset了,并不是变量内容被销毁了,只是删除了变量名和变量内容的绑定。
栗子:
$a = "hihaha";
$b = &$a;
$c = "eita";
$b = &$c;
echo $a; //输出hihaha