php的引用

  php的引用(就是在變量或者函數、對象等前面加上&符號) //最重要就是 刪除引用的變量 ,只是引用的變量訪問不了,可是內容並無銷燬 在PHP 中引用的意思是:不一樣的名字訪問同一個變量內容.php

變量的引用
        
PHP 的引用容許你用兩個變量來指向同一個內容 數組

複製代碼
<?php
$a="ABC"; 
$b =&$a; 
echo $a;//這裏輸出:ABC 
echo $b;//這裏輸出:ABC 
$b="EFG"; 
echo $a;//這裏$a的值變爲EFG 因此輸出EFG echo $b;//這裏輸出EFG 
?>
複製代碼

      函數的傳址調用 傳址調用我就很少說了 下面直接給出代碼函數

複製代碼
<?php
function test(&$a){ 
    $a=$a+100; 
} 
$b=1; 
echo $b;//輸出1 test($b);   //這裏$b傳遞給函數的實際上是$b的變量內容所處的內存地址,經過在函數裏改變$a的值 就能夠改變$b的值了 echo "<br>"; echo $b;//輸出101
?>
複製代碼


 要注意的是,在這裏test(1);的話就會出錯,緣由是:PHP規定傳遞的引用不能爲常量(能夠看錯誤提示)。this

函數的引用返回 先看代碼spa

複製代碼
<?php
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的值變爲了5code

這裏是爲了讓你們理解函數的引用返回才使用靜態變量的,其實函數的引用返回多用在對象中對象

對象的引用 blog

複製代碼
<?php
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中的運行效果 在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。 function quoteTest(){ global $var ; //至關於 $var = &$GLOBALS['var']; unset($var); //刪除只是刪除引用,而引用的內容還存在,同上這並不意味着變量內容被銷燬了}$var=1;quoteTest();echo $var; //  結果 1

----------------------------------------------------------------------------------------------

不會 unset $b,只是 $a。

function quoteTest(){ global $var ; //至關於 $var = &$GLOBALS['var']; $var = 5; //由於他們都指向 同一內存內容}$var=1;quoteTest();echo $var; //結果 5----------------------------------------------------------------------------------------------

'&' 這就是引用

 

global 引用 當用 global $var 聲明一個變量時實際上創建了一個到全局變量的引用。也就是說和這樣作是相同的:

<?php $var =& $GLOBALS["var"]; ?>

這意味着,例如,unset $var 不會 unset 全局變量。

$this 在一個對象的方法中,$this 永遠是調用它的對象的引用。

//下面再來個小插曲 php中對於地址的指向(相似指針)功能不是由用戶本身來實現的,是由Zend核心實現的,php中引用採用的是「寫時拷貝」的原理,就是除非發生寫操做,指向同一個地址的變量或者對象是不會被拷貝的。

通俗的講 1:若是有下面的代碼 [php] $a="ABC"; $b=$a; [/php] 其實此時 $a與$b都是指向同一內存地址 而並非$a與$b佔用不一樣的內存

2:若是在上面的代碼基礎上再加上以下代碼 [php] $a="EFG"; [/php] 因爲$a與$b所指向的內存的數據要從新寫一次了,此時Zend核心會自動判斷 自動爲$b生產一個$a的數據拷貝,從新申請一塊內存進行存儲

相關文章
相關標籤/搜索