PHP基礎(chǔ)之引用的解釋1——引用是什么、不是什么、做什么
PHP 的引用允許用兩個變量來指向同一個內(nèi)容。意思是,當(dāng)這樣做時:
<?php $a =& $b;?>
這意味著 $a 和 $b 指向了同一個變量。
Note:
$a 和 $b 在這里是完全相同的,這并不是 $a 指向了 $b 或者相反,而是 $a 和 $b 指向了同一個地方。
Note:
如果具有引用的數(shù)組被拷貝,其值不會解除引用。對于數(shù)組傳值給函數(shù)也是如此。
Note:
如果對一個未定義的變量進(jìn)行引用賦值、引用參數(shù)傳遞或引用返回,則會自動創(chuàng)建該變量。
Example #1 對未定義的變量使用引用
<?php function foo(&$var) { } foo($a); // $a is 'created' and assigned to null $b = array(); foo($b[’b’]); var_dump(array_key_exists(’b’, $b)); // bool(true) $c = new StdClass; foo($c->d); var_dump(property_exists($c, ’d’)); // bool(true)?>
同樣的語法可以用在函數(shù)中,它返回引用,以及用在 new 運(yùn)算符中(PHP 4.0.4 以及以后版本):
<?php $bar =& new fooclass(); $foo =& find_var($bar);?>
自 PHP 5 起,new 自動返回引用,因此在此使用 =& 已經(jīng)過時了并且會產(chǎn)生 E_STRICT 級別的消息。
Note:
不用 & 運(yùn)算符導(dǎo)致對象生成了一個拷貝。如果在類中用 $this,它將作用于該類當(dāng)前的實例。沒有用 & 的賦值將拷貝這個實例(例如對象)并且 $this 將作用于這個拷貝上,這并不總是想要的結(jié)果。由于性能和內(nèi)存消耗的問題,通常只想工作在一個實例上面。
盡管可以用 @ 運(yùn)算符來抑制構(gòu)造函數(shù)中的任何錯誤信息,例如用 @new,但用 &new 語句時這不起效果。這是 Zend 引擎的一個限制并且會導(dǎo)致一個解析錯誤。
Warning如果在一個函數(shù)內(nèi)部給一個聲明為 global 的變量賦于一個引用,該引用只在函數(shù)內(nèi)部可見??梢酝ㄟ^使用 $GLOBALS 數(shù)組避免這一點。
Example #2 在函數(shù)內(nèi)引用全局變量
<?php $var1 = 'Example variable'; $var2 = ''; function global_references($use_globals) {global $var1, $var2;if (!$use_globals) { $var2 =& $var1; // visible only inside the function} else { $GLOBALS['var2'] =& $var1; // visible also in global context} } 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; 當(dāng)成是 $var =& $GLOBALS[’var’]; 的簡寫。從而將其它引用賦給 $var 只改變了本地變量的引用。
Note:
如果在 foreach 語句中給一個具有引用的變量賦值,被引用的對象也被改變。
Example #3 引用與 foreach 語句
<?php $ref = 0; $row =& $ref; foreach (array(1, 2, 3) as $row) {// do something } echo $ref; // 3 - last element of the iterated array?>
引用做的第二件事是用引用傳遞變量。這是通過在函數(shù)內(nèi)建立一個本地變量并且該變量在呼叫范圍內(nèi)引用了同一個內(nèi)容來實現(xiàn)的。例如:
<?php function foo(&$var) {$var++; } $a=5; foo($a);?>
將使 $a 變成 6。這是因為在 foo 函數(shù)中變量 $var 指向了和 $a 指向的同一個內(nèi)容。
引用做的第三件事是引用返回。
引用不是什么如前所述,引用不是指針。這意味著下面的結(jié)構(gòu)不會產(chǎn)生預(yù)期的效果:
<?php function foo(&$var) {$var =& $GLOBALS['baz']; } foo($bar);?>
這將使 foo 函數(shù)中的 $var 變量在函數(shù)調(diào)用時和 $bar 綁定在一起,但接著又被重新綁定到了 $GLOBALS['baz'] 上面。不可能通過引用機(jī)制將 $bar 在函數(shù)調(diào)用范圍內(nèi)綁定到別的變量上面,因為在函數(shù) foo 中并沒有變量 $bar(它被表示為 $var,但是 $var 只有變量內(nèi)容而沒有調(diào)用符號表中的名字到值的綁定)??梢允褂靡梅祷貋硪帽缓瘮?shù)選擇的變量。
相關(guān)文章:
