php中global 與 $GLOBALS[""] 差別 原本覺得global和$GLOBALS除了寫法不一樣覺得,其他都一樣,可是在實際利用中發現2者的差別還是很大的!
先看下面的例子:
PHP代碼
<?PHP
// 例子1
function test_global() {
global $var1, $var2;
$var2 =& $var1;
}
function test_globals() {
$GLOBALS['var3'] =& $GLOBALS['var1'];
}
$var1 = 5;
$var2 = $var3 = 0;
test_global();
print $var2 ."n";
test_globals();
print $var3 ."n";
?>
履行效果為:
0
5
怎麼會這樣呢?不該當是2個5嗎?怎麼會出現1個0和1個5呢?
恩,我們保存以上問題,深入 分析 $GLOBALS和global的原理!
我們都知道變量其實是相應物理內存在代碼中的"代號",
引用PHP手冊的$GLOBALS的解釋 :
Global 變量:$GLOBALS
注意: $GLOBALS 在 PHP 3.0.0 及以後版本中實用。
由所有已定義全局變量組成的數組。變量名就是該數組的索引。
這是一個“superglobal”,或者可以描繪為主動全局變量。
也就是說上面代碼中的$var1和$GLOBALS['var1']是指的同一變量,而不是2個不同的變量!
下面來分析 global到底做了什麼?
我們都知道PHP中的函數所產生 的變量都是函數的私有變量,那麼global產生的變量也確定逃不出這個規矩,為什麼這麼說呢,看下面的代碼:
PHP代碼
<?PHP
function test() {
global $a;
unset($a);
}
$a = 1;
test();
print $a;
?>
復制代碼
履行效果為:
1
為什麼會輸出1呢?不是已經把$a給unset了嗎?unset失靈了?PHP的bug?
都不是,其實unset起作用了,是把test函數中的$a給unset掉了,可以在函數後面參加
print $a;
也就是說global產生 了test函數外部$a的別名 變量“$a”,為了和外面的$a差別
接著回到上面的例子1,看test_global中的這一代碼“$var2 =& $var1;”,上面是一個引用賦值運算,也就是$var2將指向var1所指向的物理內存地址
所以我們得出一個結論,在函數中global和$GLOBALS[]的差別在於:
global在函數產生 一個指向函數外部變量的別名 變量,而不是真正的函數外部變量,一但轉變了別名 變量的指向地址,就會產生一些意料不到情況 ,例如例子1.
$GLOBALS[]確確鑿實調用是外部的變量,函數內外會始終維持一致!
可以對照 下面兩個列子:
global:
<?php
function myfunction(){
global $bar;
unset($bar);
}
$bar="someting";
myfunction();
echo $bar;
?>
輸出:someting
$global[]:
<?php
function foo()
{
unset($GLOBALS['bar']);
}
$bar = "something";
foo();
echo $bar;
?>
輸出:空
PHP 的全局變量和 C 語言有一點點不同,在 C 語言中,全局變量在函數中主動生效,除非被局部變量籠罩。這可能引起一些問題,有些人可能漫不經心的轉變一個全局變量。PHP 中全局變量在函數中應用時必須 申明 為全局。
應用 global的例子
<?php
$a = 1;
$b = 2;
function Sum()
{
global $a, $b;
$b = $a + $b;
}
Sum();
echo $b;
?>
以上腳本的輸出將是 "3"。在函數中申明 了全局變量 $a 和 $b,任何變量的所有引用變量都會指向到全局變量