原來以為global和$GLOBALS除了寫法不一樣以為,其他都一樣,可是在實際應用中發現,2者的區別還是很大的!
先看下面的例子:
- <?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";
- ?>
復制代碼
執行結果為:
怎么會這樣呢?不應該是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
- // 例子2
- function test() {
- global $a;
- unset($a);
- }
- $a = 1;
- test();
- print $a;
- ?>
復制代碼
執行結果為:
為什么會輸出1呢?不是已經把$a給unset了嗎?unset失靈了?php的bug?
都不是,其實unset起作用了,是把test函數中的$a給unset掉了,可以在函數后面加入
所以我們得出一個結論,在函數中global和$GLOBALS[]的區別在于:
global在函數產生一個指向函數外部變量的別名變量,而不是真正的函數外部變量,一但改變了別名變量的指向地址,就會發生一些意料不到情況,例如例子1.
$GLOBALS[]確確實實調用是外部的變量,函數內外會始終保持一致!