變量范圍
變量的范圍即它定義的上下文背景(也就是它的生效范圍)。大部分的 PHP 變量只有一個單獨的范圍。這個單獨的范圍跨度同樣包含了 include 和 require 引入的文件。例如:
這裡變量 $a 將會在包含文件 b.inc 中生效。但是,在用戶自定義函數中,一個局部函數范圍將被引入。任何用於函數內部的變量按缺省情況將被限制在局部函數范圍內。例如:
代碼如下 復制代碼<?php
$a = 1; /* global scope */
function Test()
{
echo $a; /* reference to local scope variable */
}
Test();
?>
這個腳本不會有任何輸出,因為 echo 語句引用了一個局部版本的變量 $a,而且在這個范圍內,它並沒有被賦值。你可能注意到 PHP 的全局變量和 C 語言有一點點不同,在 C 語言中,全局變量在函數中自動生效,除非被局部變量覆蓋。這可能引起一些問題,有些人可能不小心就改變了一個全局變量。PHP 中全局變量在函數中使用時必須申明為global。
在PHP 中引用的意思是:不同的名字訪問同一個變量內容.
與C語言中的指針是有差別的.C語言中的指針裡面存儲的是變量的內容在內存中存放的地址
變量的引用
函數的傳址調用
傳址調用我就不多說了 下面直接給出代碼
要注意的是,在這裡test(1);的話就會出錯,原因自己去想
函數的引用返回
先看代碼
<?php
function &test()
{
static $b=0;//申明一個靜態變量
$b=$b+1;
echo $b;
return $b;
}
$a=test();//這條語句會輸出 $b的值 為1
echo "<br/>";
$a=5;
$a=test();//這條語句會輸出 $b的值 為2
echo "<br/>";
$a=&test();//這條語句會輸出 $b的值 為3
echo "<br/>";
$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
這裡是為了讓大家理解函數的引用返回才使用靜態變量的,其實函數的引用返回多用在對象中
對象的引用
<?php
class a{
public $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.
比如下面的例子
<?php
class a{
public $abc="ABC";
}
$b=new a;
$c=$b;
$d = clone$b;
echo $b->abc;//這裡輸出ABC
echo $c->abc;//這裡輸出ABC
$b->abc="DEF";
echo $c->abc;//這裡輸出DEF
echo $b->abc;//這裡輸出DEF
$d->abc="111";
echo $d->abc;//這裡輸出111
echo $b->abc;//這裡輸出DEF,說明clone後的副本$d對象的改變並沒有影響$b對象
?>
引用的作用
如果程序比較大,引用同一個對象的變量比較多,並且希望用完該對象後手工清除它,個人建議用 "&" 方式,然後用$var=null的方式清除. 其它時候還是用php5的默認方式吧. 另外, php5中對
於大數組的傳遞,建議用 "&" 方式, 畢竟節省內存空間使用。
取消引用
當你 unset 一個引用,只是斷開了變量名和變量內容之間的綁定。這並不意味著變量內容被銷毀了。例如:
不會 unset $b,只是 $a。
global 引用
當用 global $var 聲明一個變量時實際上建立了一個到全局變量的引用。也就是說和這樣做是相同的:
$var =& $GLOBALS["var"];
?>
這意味著,例如,unset $var 不會 unset 全局變量。
$this
在一個對象的方法中,$this 永遠是調用它的對象的引用。
//下面再來個小插曲
php中對於地址的指向(類似指針)功能不是由用戶自己來實現的,是由Zend核心實現的,php中引用采用的是“寫時拷貝”的原理,就是除非發生寫操作,指向同一個地址的變量或者對象是
不會被拷貝的。
通俗的講
1:如果有下面的代碼
$a="ABC";
$b=$a;
其實此時 $a與$b都是指向同一內存地址 而並不是$a與$b占用不同的內存
2:如果在上面的代碼基礎上再加上如下代碼
$a="ABC";
$b=$a;
$a="EFG";
由於$a與$b所指向的內存的數據要重新寫一次了,此時Zend核心會自動判斷 自動為$b生產一個$a的數據拷貝,重新申請一塊內存進行存儲
php 學習之變量傳遞!
1 用url傳遞變量
實例
代碼如下 復制代碼<html>
<head>
<title>my favorite moviesite</title>
</head>
<body>
<?php
echo "my favorite movie site is :";
echo $_GET['favmovie'];
echo "</br>";
$movierate= 5 ;
echo "my favorite movie rating for this movie is ";
echo $movierate;
?>
</body>
</html>
將這個文件保存為movie1.php.
用$_GET['favmovie']來接收url傳遞的變量!
寫入另外一個文件保存為
moviesite.php
代碼如下 復制代碼
<html>
<head>
<title> find my favorite movie</title>
</head>
<body>
<?php
//$myfavmovie=urlencode("life of brian");
echo "<a href="moviesite.php?favmovie=strips">";
echo "click here to see more information about my favorite movie!";
echo "</a>";
?>
</body>