最安全清空数组的方式是$arr = [];,语义清晰且保持变量为数组类型;需保留引用时用array_splice($arr, 0);禁用unset($arr)、$arr = null、foreach+unset及array_values()等错误方式。

直接赋值空数组最安全
多数时候你只是想让数组变空,[] 是最直白、最不容易出错的方式。它不依赖数组类型(索引/关联),也不影响原变量引用关系(除非你特意用了引用赋值)。
常见错误现象:unset($arr) 看起来像清空,其实删的是整个变量,后续再用 $arr 会报 Undefined variable;而 $arr = null 后,is_array($arr) 就返回 false,容易引发逻辑断裂。
-
$arr = [];—— 推荐,语义清晰,保持变量仍是数组类型 -
$arr = array();—— 兼容老版本 PHP,但没必要,[]在 PHP 5.4+ 已完全等价 - 避免
unset($arr);或$arr = null;,除非你真想销毁变量本身
用 array_splice() 原地截断所有元素
如果你需要保留原数组变量的引用(比如它被其他变量 &$ref = $arr 引用过),array_splice() 能真正“清空内容”,而不是换一个新数组对象。
使用场景:函数内修改传入的数组引用,外部调用者期望看到原数组被清空,而非被替换成新数组(PHP 中数组是值拷贝,但加了 & 就是引用)。
立即学习“PHP免费学习笔记(深入)”;
-
array_splice($arr, 0);—— 第二个参数为 0 表示从开头删到末尾,返回被删元素,$arr变为空数组 - 注意:必须传变量本身,不能传表达式,比如
array_splice($arr + $other, 0)会报错 - 性能上比
$arr = []略慢,但差异微乎其微,仅在极端高频调用时需留意
foreach + unset() 不适合清空数组
很多人直觉写 foreach ($arr as $k => $v) { unset($arr[$k]); },这看似合理,实则危险——PHP 数组遍历时内部指针和键的删除行为不稳定,尤其在关联数组中极易漏删或触发警告。
错误现象:Notice: Undefined index、循环只跑一半、某些键残留。PHP 官方文档也明确不建议边遍历边 unset 键。
- 绝对不要用
foreach配合unset清空数组 - 如果非得用
unset,先用array_keys($arr)拿全键,再遍历键列表删除:foreach (array_keys($arr) as $k) { unset($arr[$k]); },但纯属绕路,不如直接$arr = [] -
reset($arr)或next($arr)在这种操作后行为不可靠,别依赖
重置索引用 array_values(),不是清空
有人混淆“清空”和“重置键”。比如 [1 => 'a', 3 => 'b'] 清空后还是空数组;但若你删掉部分元素后想让键变成 [0 => 'a', 1 => 'b'],那才是 array_values() 的事——它不改变元素数量,只重排数字键。
典型误用:$arr = array_values($arr); 写在清空逻辑里,结果数组没空,只是键被重整了。
-
array_values($arr)返回新数组,原$arr不变(除非重新赋值) - 它只对数字键有效,关联键会被丢弃并重编号,
['a' => 1, 'b' => 2]经它处理后变成[0 => 1, 1 => 2] - 清空和重索引是两个独立需求,别混在一起写
真正要清空,就选 $arr = [];要保引用,用 array_splice($arr, 0);其余方案要么多余,要么埋雷。数组键的稀疏性、引用计数、内部哈希表重建这些细节,平时不用管,但一旦踩进 foreach + unset 的坑,debug 时就很难一眼看出问题在哪。











