php的引用就是在變量或者函數、對象等前面加上&符號。在PHP 中引用的意思是:不同的名字訪問同一個變量內容。與C語言中的指針是有差別的,C語言中的指針裡面存儲的是變量的內容在內存中存放的地址。
PHP 的引用允許你用兩個變量來指向同一個內容。
<? $a="ABC"; $b =&$a; echo $a;//這裡輸出:ABC echo $b;//這裡輸出:ABC $b="EFG"; echo $a;//這裡$a的值變為EFG 所以輸出EFG echo $b;//這裡輸出EFG ?>
傳址調用我就不多說了,下面直接給出代碼:
function test(&$a) { $a=$a+100; } $b=1; echo $b;//輸出1 test($b); //這裡$b傳遞給函數的其實是$b的變量內容所處的內存地址,通過在函數裡改變$a的值 就可以改變$b的值了 echo "<br />"; echo $b;//輸出101
要注意的是,在這裡test(1);的話就會出錯,原因自己去想。
先看代碼:
function &test() { static $b=0;//申明一個靜態變量 $b=$b+1; echo $b; return $b; } $a=test();//這條語句會輸出 $b的值 為1 $a=5; $a=test();//這條語句會輸出 $b的值 為2 $a=&test();//這條語句會輸出 $b的值 為3 $a=5; $a=test();//這條語句會輸出 $b的值 為6
通過這種方式$a=test();得到的其實不是函數的引用返回,這跟普通的函數調用沒有區別。至於原因:這是PHP的規定。PHP規定通過$a=&test(); 方式得到的才是函數的引用返回。至於什麼是引用返回呢(PHP手冊上說:引用返回用在當想用函數找到引用應該被綁定在哪一個變量上面時。)
用上面的例子來解釋就是:
$a=test()方式調用函數,只是將函數的值賦給$a而已,而$a做任何改變都不會影響到函數中的$b。而通過$a=&test()方式調用函數呢,他的作用是將return $b中的 $b變量的內存地址與$a變量的內存地址 指向了同一個地方即產生了相當於這樣的效果($a=&b;) 所以改變$a的值也同時改變了$b的值,所以在執行了
$a=&test(); $a=5;
以後,$b的值變為了5。
這裡是為了讓大家理解函數的引用返回才使用靜態變量的,其實函數的引用返回多用在對象中。
<? class a{ var $abc="ABC"; } $b=new a; $c=$b; echo $b->abc;//這裡輸出ABC echo $c->abc;//這裡輸出ABC $b->abc="DEF"; echo $c->abc;//這裡輸出DEF ?>
在PHP5中對象的復制是通過引用來實現的。上列中$b=new a; $c=$b; 其實等效於$b=new a; $c=&$b;PHP5中默認就是通過引用來調用對象,但有時你可能想建立一個對象的副本,並希望原來的對象的改變不影響到副本。為了這樣的目的,PHP定義了一個特殊的方法,稱為__clone.
引用的作用:如果程序比較大,引用同一個對象的變量比較多,並且希望用完該對象後手工清除它,個人建議用 "&" 方式,然後用$var=null的方式清除。其它時候還是用php5的默認方式吧。另外,php5中對於大數組的傳遞,建議用 "&" 方式,畢竟節省內存空間使用。
當你 unset 一個引用,只是斷開了變量名和變量內容之間的綁定。這並不意味著變量內容被銷毀了。例如:
<?php $a = 1; $b =& $a; unset ($a); ?>
不會 unset $b,只是 $a。
當用 global $var 聲明一個變量時實際上建立了一個到全局變量的引用。也就是說和這樣做是相同的:
<?php $var =& $GLOBALS["var"]; ?>
這意味著,例如,unset $var 不會 unset 全局變量。
$this 在一個對象的方法中,$this 永遠是調用它的對象的引用。
php中對於地址的指向(類似指針)功能不是由用戶自己來實現的,是由Zend核心實現的,php中引用采用的是"寫時拷貝"的原理,就是除非發生寫操作,指向同一個地址的變量或者對象是不會被拷貝的。
通俗的講,如果有下面的代碼:
$a="ABC"; $b=$a;
其實此時$a與$b都是指向同一內存地址,而並不是$a與$b占用不同的內存。
如果在上面的代碼基礎上再加上如下代碼:
$a="EFG";
由於$a與$b所指向的內存的數據要重新寫一次了,此時Zend核心會自動判斷 自動為$b生產一個$a的數據拷貝,重新申請一塊內存進行存儲。