PHP作用域:全局环境和局部环境彼此独立隔离,互相不能访问各自里面的变量。
这里我们首先要明白一个知识点:
global $a是外部$a的同名引用
从下面这个例子我们可以看出:$GLOBALS['a']是外部的全局变量$a本身
$a = 1;
function test(){
unset($GLOBALS['a']);
}
test();
echo $a;
什么都没输出,因为此时$a已经被unset了
$a=1;
function test(){
global $a;
unset($a);
}
test();
echo $a;
输出1
证明删除的只是别名,$GLOBALS['a']的引用,其本身的值没有受到任何改变
也就是说global $a其实就相当于$a = &$GLOBALS['a']。调用外部变量的一个别名。
$a=0;
function test(){
global $a;
$a = 1;
}
test();
echo $a;//输出1
即上述代码相当于
$a=0;
function test(){
$a = &$GLOBALS['a'];
$a = 1;
}
test();
echo $a;//输出1
故而当$a在函数体中发生改变时,由于引用传值的关系$GLOBALS['a']的值也就变成了1,故而外部的$a的值也就变成了1
但一旦用了&,那么变量将不再是同名引用。
例:
$a=1;
$b=2;
function test(){
global $a,$b;
$a = $b;
}
test();
echo $a;//输出2
由于同名引用的关系,此时函数体内$b的值为2,故而函数体内的$a的值为2,由于函数体内$a是对外部$a的同名引用,故而外部$a也就是2
$a=1;
$b=2;
function test(){
global $a,$b;
$a = &$b;
}
test();
echo $a;//输出1
由于此时函数体内$a=&$b;由于&的关系,故而此时函数体内的$a已不再是对外部$a的同名引用,所以当函数体内的$a=2时,外部的$a并没有改变。
我们再来看个例子:
$a=1;
$b=2;
function test(){
global $a,$b;
$a = &$b;
$a=8;
}
test();
echo $a;echo $b;//输出18
此时函数体内的$a=8;由于引用传值的关系,函数体内的$b=8,再由于函数体内的$b对于外部的$b的同名引用,故而外部的$b=8
而由于&的关系,函数体内的$a与外部$a已不再是同名引用,故而外部的$a的值没有改变