登录
首页 >  文章 >  php教程

PHP引用传递符号&使用技巧

时间:2026-05-19 18:13:26 341浏览 收藏

PHP中的引用符号&并非简单的“传地址”,而是让变量共享同一块内存空间,其使用充满精妙却易错的细节:函数参数加&仅接受可写变量,传表达式会直接报错;引用赋值$b=&$a实现双向同步修改;返回引用必须用&接收,否则静默失效、逻辑悄然崩坏;foreach中使用&$v后若不unset($v),将遗留指向最后一个元素的隐性引用,引发难以追踪的脏数据问题——这些看似微小的语法约定,实则是PHP引用机制的核心命门,稍有不慎便让程序在无声中偏离预期。

PHP中的引用传递&符号怎么用_掌握变量内存地址的共享技巧

PHP 的 & 不是“传地址”,而是让两个变量共享同一块内存空间;用错地方会直接报 Cannot pass parameter 1 by reference 或引发静默逻辑错误。

函数参数加 & 只接受变量,不接受表达式

函数定义里写 function foo(&$x) { ... },调用时必须传一个**可写变量**,不能是字面量、数组下标访问、对象属性、函数调用结果。

  • foo($var) ✅ 正常
  • foo($arr[0]) ❌ PHP 7.4+ 明确拒绝,报 Only variables can be passed by reference
  • foo(get_data()) ❌ 返回值不是变量,无法绑定引用
  • foo($obj->prop) ❌ PHP 7.4 起对对象属性引用更严格,多数情况报错

常见误判:以为“只要能读出来就能传”,其实引用传递要求变量在内存中可寻址、可修改。临时值没有地址,不能被引用。

$b = &$a 是引用赋值,不是复制

这行代码让 $b$a 指向同一内存位置,后续任一变量修改都会同步到另一个。

  • $a = 10; $b = &$a; $b = 20;$a 变成 20
  • unset($a) 不影响 $b$b 仍有效(PHP 不销毁共享内容)
  • $b = 123 是改值,不是重绑定新引用;想换指向得重新 =&

注意:unset($b) 后再访问 $bNULL,但 $a 值不受影响 —— 引用关系解除,不是内容销毁。

返回引用必须用 & 接收,漏写就白忙活

函数声明为 function &get_ref() { static $x = 0; return $x; },调用时若写 $r = get_ref();,得到的是副本;只有 $r = &get_ref(); 才真正拿到引用。

  • echo get_ref(); ✅ 输出当前值
  • $r = get_ref(); $r = 99;get_ref() 内部的 $x 不变
  • $r = &get_ref(); $r = 99;$x 被改写,下次调用 get_ref() 返回 99

调用方漏写 & 是静默失败,没有任何报错提示,调试时极难定位 —— 这是最容易被忽略的坑。

foreach 中用 &$v 后记得 unset($v)

foreach ($arr as &$v) { $v *= 2; } 确实能原地改数组,但循环结束后 $v 仍引用着最后一个元素。

  • 后续若再写 $v = 123;,会意外改掉 $arr 最后一项
  • 解决方法:循环后立即 unset($v),断开残留引用
  • PHP 8.0+ 对此有警告提示,但低版本完全静默

这个残留引用不是 bug,是语言设计行为,但几乎每次都会导致难以复现的脏数据问题。

今天带大家了解了的相关知识,希望对你有所帮助;关于文章的技术知识我们会一点点深入介绍,欢迎大家关注golang学习网公众号,一起学习编程~

资料下载
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>