本文主要是介绍PHP中global与$GLOBALS['']的区别,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
很多人都认为global与$GLOBALS[]只是写法上面的差别,其实不然。
根据官方的解释是:
GLOBALS[′var′]是外部的全局变量 var本身。
global var是外部 var的同名引用或者指针。
一开始看到这句话,有点理解,拗口,别急,下面我们来看看这些例子:
<?php$var1=1;$var2=2;function test(){$GLOBALS['var2']=&$GLOBALS['var1'];}test();echo $var2;
?>
output:
1
For example:
$var1=1;
$var2=2;
function test(){global $var1,$var2;$var2=&$var1;echo $var2;$var2="snsgou.com";
}
test();
echo $var2;
echo $var1;
output:
1
2
snsgou.com
注:对上述结果的输出“snsgou.com”是不是有点差异,下面我们来看看解释:
test()函数中的 var1, var2都是局部变量,只不过是加了global关键字之后,分别引用指向全局变量 var1, var2了,当var2=&var1;时,局部变量 var2不再指向全局变量 var2,而重新指向全局变量 var1,换句话说,局部变量 var2的改变,不会再影响到全局变量 var2,而会影响到重新指向的全局变量 var1;
我们再来看一下这个例子:
$var1=1;
function test(){unset($GLOBALS['var1']);
}
test();
echo $var1;
output:
************这里不会输出任何东西**********
<?php$var1=1;function test(){global $var1;unset($var1);}test();echo $var1;
?>
output:
1
证明删除的只是别名:$GLOBALS[‘var’]的引用,其本身的值没有收到任何的改变;
也就说明global var其实就是 var=&GLOBALS[‘var’]
,调用外部变量的一个别名而已;
PHP中global和$GLOBALS不仅仅是写法不一样,二者的区别还是很大的,在实际应用中需要注意!,请看下面的这个例子:
<?php$id=1;function test(){global $id;unset($id);}test();echo($id);
?>
output:
1
许多PHP的语法结构是通过引用机制实现的,所以上述有关引用绑定的一切也都适用于这些结构。一些结构,例如引用传递和引用返回,已经在上面提到了。其他使用引用的结构有:
当用global $var 声明一个变量时实际上建立了一个全局变量的引用,也就是说和这样做是相同的:
$GLOBAL["var1"]=1;
$var=&$GLOBALS["var1"];
unset($var);
echo $GLOBALS["var1"];
output: 1
$GLOBALS["var1"]=1;
$var=&$GLOBALS["var1"];
unset($GLOBALS['var1']);
echo $var;
output: 1
$GLOBALS["var"]=1;
$var=&$GLOBALS["var"];
unset($GLOBALS["var"]);
echo $var;
output:
Notice: Undefined variable: var in D:\www\namespace5\index2.php on line 23
这意味着,例如,unset var不会unset全局变量。unset只是把只是断开了变量名和变量内容之间的绑定。这并不意味着变量内容被销毁了。使用isset( var)的时候返回 false。 this在一个对象的方法中, this 永远是调用它的对象的引用。
如果在一个函数内部给一个声明为 global 的变量赋于一个引用,该引用只在函数内部可见。
可以通过使用 $GLOBALS 数组避免这一点。
例 在函数内引用全局变量:
<?php$var="For example";$var2="";function test($user_globals){global $var1,$var2;if(!$user_globals){$var2=&$var1;}else{$GLOBALS["var2"]=&$var1;}}test(false);echo "var2 is set to '$var2'";test(true);echo "var2 is set to '$var2'";
?>
把global var;当成是 var=& GLOBALS[′var′]的简写。所以如果将其它引用赋给 var, 只改变了本地变量的引用。
如前所述,引用不是指针。这意味着下面的结构不会产生预期的效果:
$bar=3;function foo(&$var){$GLOBALS["baz"]=5;$var=&$GLOBALS["baz"];}foo($bar);echo $bar;
output:
3
这将使 foo 函数中的 var变量在函数调用时和 bar 绑定在一起,但接着又被重新绑定到了 GLOBALS[“baz”]上面。不可能通过引用机制将 bar 在函数调用范围内绑定到别的变量上面,因为在函数 foo 中并没有变量 bar(它被表示为 var,但是 $var 只有变量内容而没有调用符号表中的名字到值的绑定)。可以使用引用返回来引用被函数选择的变量。
引用PHP手册的 GLOBALS的解释:GLOBAL变量: GLOBALS,注意:$GLOBALS 在PHP3.0.0及以后版本中适用。
由所有已定义全局变量组成的数组。变量名就是该数组的索引。这是一个“superglobal”,或者可以描述为自动全局变量。
也就是说上面代码中的 var1和 GLOBALS[‘var1’]是指的同一变量,而不是2个不同的变量!
如果在一个函数内部给一个声明为 global 的变量赋于一个引用,该引用只在函数内部可见。可以通过使用 $GLOBALS 数组避免这一点。
我们都知道php中的函数所产生的变量都是函数的私有变量,那么global关键字产生的变量也肯定逃不出这个规则,global在函数产生一个指向函数外部变量的别名变量,而不是真正的函数外部变量,一但改变了别名变量的指向地址,就会发生一些意料不到情况,$GLOBALS[]确确实实调用是外部的变量,函数内外会始终保持一致。
<?php
$a=1;
$b=2;
function test(){global $a,$b;$b=$a+$b;
}
sum();
echo $b;
?>
output:
3
注意:为什么输出的是3?而不是2呢。在函数外部不是不影响吗,请注意 b在函数中并没有通过引用修改,而修改的是 b指向 a与 b两个物理内存的值,因此外部输出3;
转载地址:http://www.php-note.com/article/detail/221
这篇关于PHP中global与$GLOBALS['']的区别的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!