PHP中global与$GLOBALS['']区别

本文通过实例解析PHP中global和$GLOBALS的区别,包括引用、指针和变量删除后的行为,帮助开发者理解两者在实际应用中的不同作用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

很多人都认为global和$GLOBALS[]只是写法上面的差别,其实不然。

根据官方的解释是

1.$GLOBALS['var']是外部的全局变量本身。

2.global $var是外部$var的同名引用或者指针。

举例说明一下:

  1. <?php  
  2. $var1 = 1;  
  3. $var2 = 2;  
  4. function test(){  
  5.      $GLOBALS['var2'] = &$GLOBALS['var1'];  
  6. }  
  7. test();  
  8. echo $var2;  
  9. ?>  
<?php $var1 = 1; $var2 = 2; function test(){ $GLOBALS['var2'] = &$GLOBALS['var1']; } test(); echo $var2; ?>

正常打印结果为1

  1. <?php  
  2. $var1 = 1;  
  3. $var2 = 2;  
  4. function test(){  
  5.      global $var1,$var2;  
  6.      $var2 = &$var1;  
  7. }  
  8. test();  
  9. echo $var2;  
  10. ?>  
<?php $var1 = 1; $var2 = 2; function test(){ global $var1,$var2; $var2 = &$var1; } test(); echo $var2; ?>

意外打印结果为2

为什么会打印结果为2呢?其实就是因为$var1的引用指向了$var2的引用地址。导致实质的值没有改变。

我们再来看一个例子吧。

  1. <?php  
  2. $var1 = 1;  
  3. function test(){  
  4.      unset($GLOBALS['var1']);  
  5. }  
  6. test();  
  7. echo $var1;  
  8. ?>  
<?php $var1 = 1; function test(){ unset($GLOBALS['var1']); } test(); echo $var1; ?>

因为$var1被删除了,所以什么东西都没有打印。

  1. <?php  
  2. $var1 = 1;  
  3. function test(){  
  4.     global  $var1;  
  5.      unset($var1);  
  6. }  
  7. test();  
  8. echo $var1;  
  9. ?>  
<?php $var1 = 1; function test(){ global $var1; unset($var1); } test(); echo $var1; ?>

意外的打印了1。证明删除的只是别名|引用,起本身的值没有受到任何的改变。

明白了吧?

也就是说global $var其实就是$var = &$GLOBALS['var']。调用外部变量的一个别名而已。

<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、付费专栏及课程。

余额充值