PHP学习之全局变量
来看一下下面的这个例子:
这个脚本不会有任何输出,因为 echo 语句引用了一个局部版本的变量 $a,而且在这个范围内,它并没有被赋值。
再看一个使用 global 的例子:
Example #1 使用 global
以上脚本的输出将是"3"。在函数中声明了全局变量 $a 和 $b 之后,对任一变量的所有引用都会指向其全局版本。对于一个函数能够声明的全局变量的最大个数,PHP 没有限制。
在全局范围内访问变量的第二个办法,是用特殊的 PHP 自定义 $GLOBALS 数组。前面的例子可以写成:
Example #2 使用 $GLOBALS 替代 global
$GLOBALS 是一个关联数组,每一个变量为一个元素,键名对应变量名,值对应变量的内容。$GLOBALS 之所以在全局范围内存在,是因为 $GLOBALS 是一个超全局变量。以下范例显示了超全局变量的用处:
Example #3 演示超全局变量和作用域的例子
全局变量的引用
请记住:如果在一个函数内部给一个声明为 global 的变量赋于一个引用,该引用只在函数内部可见。
在 Zend 引擎 1 代,它驱动了 PHP4,对于变量的 static 和 global 定义是以引用的方式实现的。例如,在一个函数域内部用 global 语句导入的一个真正的全局变量实际上是建立了一个到全局变量的引用。这有可能导致预料之外的行为,如以下例子所演示的:
以上例程会输出:
NULL
object(stdClass)(0) {
}
第一次输出NULL,原因是因为 global $var; 是 $var =& $GLOBALS['var']; 的简写。从而将其它引用赋给 $var 只改变了本地变量$var的引用。
也就是说$obj = &new stdclass;这个语句改变了局部变量$obj的指向, global $obj 这句语句造成的效果已经被覆盖了。
类似的行为也适用于 static 语句。引用并不是静态地存储的:
property++; return $obj;}function &get_instance_noref() { static $obj; echo 'Static object: '; var_dump($obj); if (!isset($obj)) { // 将一个对象赋值给静态变量 $obj = new stdclass; } $obj->property++; return $obj;}$obj1 = get_instance_ref();$still_obj1 = get_instance_ref();echo "\n";$obj2 = get_instance_noref();$still_obj2 = get_instance_noref();?>
以上例程会输出:
Static object: NULL
Static object: NULL
Static object: NULL
Static object: object(stdClass)(1) {
["property"]=>
int(1)
}