php数组操作顺序决定结果:键名覆盖以最后赋值为准,+=保留左侧键,foreach中修改数组行为因版本而异,函数链式调用从左到右执行,+与array_merge键处理逻辑相反。

PHP 数组操作的顺序直接影响最终结果,尤其在涉及键名冲突、引用赋值、函数链式调用或 foreach 遍历时,稍不注意就会得到意外输出。
键名覆盖:后写入的值会覆盖先写入的同名键
PHP 关联数组中,键名唯一。若多次对同一键赋值,仅最后一次生效:
$arr = ['a' => 1, 'b' => 2]; $arr['a'] = 99; // 覆盖原值 $arr['c'] = 3; // 结果:['a'=>99, 'b'=>2, 'c'=>3]
- 索引数组(数字键)也遵循此规则,如
$arr[0] = 1; $arr[0] = 5;最终$arr[0]是 5 - 使用
+=合并数组时,右侧数组中已存在的键不会被覆盖(左侧优先),顺序不可颠倒
foreach 遍历中修改数组:行为取决于 PHP 版本和操作类型
在循环中增删元素,可能跳过项或触发重复遍历:
$arr = [0 => 'a', 1 => 'b', 2 => 'c'];
foreach ($arr as $k => $v) {
if ($k == 1) unset($arr[$k]); // 删除键 1
}
// PHP 7.4+:仍遍历全部原始键(0,1,2),但 $arr[1] 已不存在,$v 为 null 或触发 notice
// PHP 8.0+:更严格,unset 后继续按原内部指针走,不会跳过后续键
- 避免在 foreach 中修改正在遍历的数组结构;如需过滤,用
array_filter() - 若必须边遍历边追加,建议先收集待添加项,循环结束后统一
+=或array_merge()
函数组合顺序决定中间状态是否保留
多个数组函数连用时,执行顺序从左到右,每一步都基于上一步结果:
立即学习“PHP免费学习笔记(深入)”;
$arr = [1, 2, 3, 4, 5]; $result = array_slice(array_map(fn($x) => $x * 2, $arr), 1, 3); // 先 map → [2,4,6,8,10],再 slice(1,3) → [4,6,8]
- 若把
array_slice放前面:array_map(..., array_slice(...)),则只对子数组做变换 - 引用传递类操作(如
&$item在 foreach 中)会影响原数组,顺序错误可能导致误改
array_merge 与 + 运算符:键处理逻辑完全不同
二者看似都能合并,但顺序和策略差异极大:
$a = ['x' => 1, 'y' => 2]; $b = ['y' => 3, 'z' => 4]; <p>var_dump($a + $b); // ['x'=>1, 'y'=>2, 'z'=>4] —— 左侧键优先,不覆盖 var_dump(array_merge($a, $b)); // ['x'=>1, 'y'=>3, 'z'=>4] —— 右侧键覆盖左侧同名键</p>
-
+保持左侧数组键的顺序,右侧重复键直接忽略 -
array_merge()重排数字键(全转为连续整数),关联键按右侧覆盖 - 混合使用时,务必确认哪部分是“主数据”,哪部分是“补丁”,再选操作符











