php中global和$GLOBALS

本文深入解析PHP中的变量类型,包括局部变量、全局变量和超全局变量的特性与使用场景。特别聚焦于超全局变量如$_GET、$_POST、$_SESSION等的功能及如何在不同HTTP请求方式下获取数据。

PHP变量介绍

php中变量分三类:局部变量,全局变量,超全局变量
局部变量:在函数内部声明的变量
全局变量,在函数外部声明的变量
超全局变量:系统定义的变量,在任何地方都可以直接调用


超全局变量

超全局变量描述
$_GET主要用来获取HTTP GET方式传递的数据
$_POST主要用来获取HTTP POST方式传递的数据
$_REQUEST只要用来获取GET和POST方式传递的数据,但是速度相对较慢
$_SERVER主要用来获取服务器执行环境的相关信息
$_GLOBALS主要包含_GET,_POST,$_COOKIE数组的内容
$_SESSION主要获取服务器端的会话信息
$_COOKIE主要获取客户端的会话信息
$_FILES主要获取上传文件的i相关信息
$ENV获取环境信息(不常用)

global和$GLOBALS[’’]

  • global $a 是外部$a的同名引用
  • $GLOABLS[‘a’]是外部的全局变量$a本身
<?php
	$a = 1;
	function test() {
		unset(\GLOBALS['a']);
	}
	
	test();
	echo $a;
?>

什么都不会输出,因为此时$a已经被unset了
 

<?php
	$a = 1;
	function test() {
		global $a;
		unset($a);
	}
	test();
	echo $a;
?>

输出1
证明删除的只是别名,$GLOBALS[‘a’]的引用,其本身的只没有受到任何改变
也就是说global $a 其实就相当与$a = &$GLOBALS[‘a’].调用外部变量的一个别名

 

<?php
	$a = 0;
	function test() {
		global $a;
		$a = 1;
	}
	test();
	echo $a;//输出1
?>

即上述代码相当于

<?php
	$a = 0;
	function test() {
		$a = &$GLOBALS['a'];
		$a = 1;
	}
	test();
	echo $a;//输出1
?>

 
但一旦用了&,那么变量将不再是同名引用

<?php
	$a = 1;
	$b = 2;
	function test() {
		global $a,$b;
		$a = $b;
	}
	test();
	echo $a;//输出2
?>

由于同名引用的关系,此时函数体内的值为2,故而函数体内的$a的值为2,由于函数体内$a是对外部$a的同名引用,故而$a为2
 

<?php
	$a = 1;
	$b = 2;
	function test() {
		global $a,$b;
		$a = &$b;
	}
	test();
	echo $a;//输出1
?>

由于此时函数体内$a=&$b;由于&的关系,故而此时函数体内的$a已不再是对外部$a的同名引用,所以当函数体内的$a=2时,外部的$a并没有改变
 

<?php
	$a = 1;
	$b = 2;
	function test() {
		global $a,$b;
		$a = &$b;
		$a = 8;
	}
	test();
	echo $a;//输出1
	echo $b;//输出8
?>
<think>嗯,用户给了一段PHP代码,让我解释一下。首先,我需要仔细看一下这段代码的结构功能。看起来像是处理API包含全局变量管理的。 首先,代码开头有static $s_api_included;,这里声明了一个静态变量,用来记录哪些API已经被包含过,避免重复加载。接着用global $g_core_path;引入了一个全局变量,应该是核心路径。然后检查$s_api_included数组中是否已经存在当前API名,如果没有,就执行require_once包含对应的文件。 接下来,使用get_defined_vars()获取当前定义的变量,然后通过array_diff_key排除$GLOBALS自身$t_new_globals,这样得到新加载的变量。然后遍历这些变量,将它们添加到$GLOBALS中,确保全局可用。最后标记该API为已加载。 需要确认用户是否了解静态变量全局变量的作用,以及他们是否在使用旧版PHP,因为array_diff_key的参数顺序可能影响结果。另外,这种全局变量管理方式可能存在安全隐患,比如变量覆盖,需要提醒用户注意。可能用户是在维护一个老项目,遇到变量作用域的问题,或者想优化资源加载。需要解释清楚代码的逻辑潜在问题,帮助他们理解或改进代码。</think>这是典型的PHP模块加载代码,我为您逐行分析其实现原理: ```php static $s_api_included; // 静态变量记录已加载的API global $g_core_path; // 引入核心路径全局变量 if( !isset( $s_api_included[$p_api_name] ) ) { // 检查是否已加载过该API require_once( $g_core_path . $p_api_name ); // 加载指定API文件 $t_new_globals = array_diff_key( get_defined_vars(), // 获取当前所有变量 $GLOBALS, // 排除已有全局变量 array( 't_new_globals' => 0 ) // 排除临时变量自身 ); foreach ( $t_new_globals as $t_global_name => $t_global_value ) { $GLOBALS[$t_global_name] = $t_global_value; // 将新变量提升为全局 } $s_api_included[$p_api_name] = 1; // 标记该API已加载 } ``` 主要功能特点: 1. **单次加载机制**:通过静态变量`$s_api_included`确保API文件只被加载一次 2. **全局变量提升**:使用`array_diff_key`对比加载前后变量差异,将新定义的变量自动注册为全局变量 3. **路径拼接**:利用`$g_core_path`全局变量构建完整文件路径 ⚠️ 注意:这种自动提升变量的做法在PHP 5.3+中存在兼容性问题(array_diff_key参数顺序问题),且存在安全隐患(可能意外覆盖全局变量),现代框架通常使用自动加载器(autoloader)替代这种模式。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值