一、超全局变量$GLOBALS

PHP超全局变量有很多,如下的都属于超全局变量(Super Global):

$GLOBALS,$_SERVER,$_GET,$_POST,$_FILES,$_COOKIE,$_SESSION,$_REQUEST,$_ENV

官方说明:

  • $GLOBALS 引用全局作用域中可用的全部变量。
  • $GLOBALS 包含了全部变量的全局组合数组(实际上是一个数组),变量的名字就是数组的键。
  • 出现过的全局变量,都可以通过$GLOBALS这个数组取得。
  • PHP生命周期中,定义在函数体外部的所谓全局变量,函数内部是不能直接获得的

 

示例代码:

$foo = "Example content";
test();
function test() {
    $foo = "local variable";
    echo '$foo in current scope: ' . $foo . "<br>";
    echo '$foo in global scope: ' . $GLOBALS["foo"] . "<br>";
}

如上的例子,要访问外部的$foo必须使用 $GLOBALS数组。对于通过include文件进来的外部全局变量也适用。

php中global也有这样的功能,它和$GLOBALS的区别在于:

  • global在函数产生一个指向函数外部变量的别名变量,而不是真正的函数外部变量。
  • $GLOBALS[]确确实实调用是外部的变量,函数内外会始终保持一致。

对于类中的成员变量,类中函数必须使用$this->的方式访问,不能用$GLOBALS方式:

global的作用是定义全局变量,但是这个全局变量不是应用于整个网站,而是应用于当前页面,包括include或require的所有文件。

 

二、实例讲解

function t1() {
    global $var1, $var2;
    $var2 = &$var1;
}
function t2() {
    $GLOBALS['var3'] = &$GLOBALS['var1'];
}
$var1 = 5;
$var2 = $var3 = 3;
t1();
print $var2 ."\n";
t2();
print $var3 ."\n";

执行结果输出为:

3
5

为什么不是2个5,而是1个3和1个5呢?

再修改一下例子:

function t1() {
    global $var1;
    $var1 = 2;
    unset($var1);
}
function t2() {
    $GLOBALS['var1'] = 3;
    unset($GLOBALS['var1']);
}
$var1 = 1;
t1();
print $var1 . "\n";
t2();
print $var1 . "\n";

执行结果只输出一个2

1、$GLOBALS是由所有已定义全局变量自动形成的数组。变量名就是该数组的索引。即$GLOBALS['var1']与函数外部的变量$var1是同一个变量,所以将$GLOBALS['var1'] 删除后,该变量已不存在,所有无法输出了。

注:$GLOBALS是自动全局变量。这意味着它在所有的脚本中都有效。在函数或方法中不需要使用 global $GLOBALS; 来访问它。

2、"global $var1;"是产生了函数外部$var1的别名变量"$var1",它不是真正的函数外部变量,他只存在于函数的内部,所以即使在函数内将别名变量删除也不会影响外面的变量,但是可以修改函数外部变量的值。

或许有的人总想知道这个或那个的区别:在php程序,包括其他程序的学习中,自己动手实验,根据结果加上的思考,有的时候比上网查找可能会来得更快一些,更准确一些。

 

php在全局范围内访问变量要怎么办?

例1:global定义全局变量

function test_global() {
    global $var1;
    $var1 = 'ok';
    unset($var1);
}
test_global();
$var2 = &$var1;
unset($var1);
echo $var2;

先不给出结果,自己运行一下程序。函数内部的变量可以访问到了。从结果可以看出,unset只是断开变量名与变量值连接,并没有马上销毁变量的值,而且在函数内部定义的全局变量,实际在外部只是使用了函数内部的别名而已,所以我们在外面依然可以访问$var1。

 

例2:$GLOBALS在函数内部访问函数外面定义的变量

$waibu = 'out';
function ff() {
    echo $waibu; // error
    echo $GLOBALS['waibu'];

    global $waibu;
    echo $waibu; // ok
}
ff();

直接在函数内部使用$waibu是会出错的,但是 global $waibu 后再访问$GLOBALS['waibu'] ,则是正确的,可以访问 。

 

示例完整代码:

<?php 
    echo "<br>===== t1-t2 ===== <br>";
    function t1(){
        global $var1, $var2;
        $var2 = &$var1;   // point -> point
        echo "t1 -- " . $var1 . " , " . $var2 . "<br>";
    }

    function t2() {
        $GLOBALS['var3'] = &$GLOBALS['var1'];       // point
        echo "t2 -- " . $GLOBALS['var3'] . " , " . $GLOBALS['var1'] . "<br>";
    }

    $var1 = 5;
    $var2 = $var3 = 3;
    t1();
    echo $var2 . "<br>";
    t2();
    echo $var3 . "<br>";


    echo "<br>===== t3-t4 ===== <br>";
    function t3(){
        global $var1;
        $var1 = 2;
        echo "t3 - " . $var1 . "<br>";
        unset($var1);
    }

    function t4(){
        $GLOBALS['var1'] = 3;
        echo "t4 - " . $GLOBALS['var1'] . "<br>";
        unset($GLOBALS['var1']);
    }

    $var1 = 1;
    t3();
    echo $var1 . "<br>";
    t4();
    echo $var1 . "<br>";


    echo "<br>===== test_global ===== <br>";
    function test_global(){
        global $var1;
        $var1 = 'ok';
        echo "test_global - " . $var1 . "<br>";
        unset($var1);
    }

    test_global();
    echo "var1 : " . $var1 . "<br>";

    $var1 = 'okok';
    $var2 = &$var1;
    unset($var1);
    echo "var2 : " . $var2 . "<br>";
?>

运行结果:

===== t1-t2 ===== 
t1 -- 5 , 5

3
t2 -- 5 , 5
5

===== t3-t4 ===== 
t3 - 2

2
t4 - 3

Notice: Undefined variable: var1 in xxx/test/test_config.php on line 40


===== test_global ===== 
test_global - ok
var1 : ok
var2 : okok

 

 

参考推荐:

PHP Global 全局变量