php函数有独立作用域,内部变量外部不可访问;foreach变量会泄漏;use默认值传递;eval作用域完全隔离。

函数内部定义的变量在外部访问会报 Undefined variable
PHP 的函数有独立作用域,函数内用 $var = 1 声明的变量,默认只在函数体内可见。外面直接写 echo $var 就会报错,不是“没赋值”,是根本找不到这个符号。
常见错误现象:Notice: Undefined variable: count in /path/to/file.php on line 12,尤其在循环后想用计数器时容易踩坑。
- 不要靠“写在前面”来让变量跨作用域——
$i = 0; function foo() { echo $i; }这样不行 - 真要共享,显式传参最安全:
function calc($start, $step) { return $start + $step; } - 极少数场景需用
global,但会破坏可测性,不推荐用于新代码 -
static变量只在函数首次调用时初始化,后续调用保留值,适合计数器或缓存,但注意它仍不可被外部读取
foreach 循环变量在循环结束后依然存在
PHP 的 foreach 不创建新作用域,循环变量会泄漏到外层。这和 JavaScript 的 for...of 或 Python 的 for 不同,容易引发意外覆盖。
使用场景:常出现在模板里嵌套循环,比如先遍历用户列表,再遍历每个用户的订单,结果发现 $user 被后一个循环改掉了。
立即学习“PHP免费学习笔记(深入)”;
- 循环结束后立即
unset($user)是最直白的补救方式 - 更稳妥的做法是起明确、不重叠的变量名:
foreach ($users as $u) { foreach ($u['orders'] as $order) { ... } } - 如果用
list()解构,变量同样会泄漏:foreach ($rows as list($id, $name))→$id和$name都留在当前作用域
use 关键字只能把外部变量“拷贝进”匿名函数,不是引用
匿名函数(closure)通过 use 捕获外部变量时,默认是值传递。改了闭包里的变量,不影响外面;外面改了,闭包里也看不到更新。
性能影响:小变量拷贝开销可忽略,但若 use 一个大数组或对象,又没加 &,可能浪费内存。
- 需要双向同步?加引用:
function () use (&$config) { $config['debug'] = true; } - 只读场景别加
&,避免误改导致逻辑混乱 - PHP 7.4+ 支持箭头函数,但箭头函数不支持
use引用,也不支持多语句,别硬套
eval() 和 create_function() 里的变量完全隔离
这两个函数执行的代码运行在全新作用域,既看不见外部变量,也不会污染外部。现在 create_function() 已废弃(PHP 8.0 移除),但老项目里还可能见到。
容易踩的坑:以为 eval("echo $x;") 能打印外部的 $x,实际会报 Undefined variable —— 因为双引号里的 $x 在 eval 执行前就被替换成空字符串了。
- 真要用
eval(不推荐),变量必须拼成字符串:eval("echo " . var_export($x, true) . ";"); - 替代方案优先选匿名函数、回调数组或
call_user_func - 任何动态代码执行都绕不开安全风险,别为了省几行代码引入
eval











