应使用 is_array($arr) && !empty($arr) 判断非空数组,避免 empty() 误判;array_merge() 重置数字键而 + 左优先;遍历时修改数组需用 array_filter 或延后操作;json_decode 保键类型宜用 stdclass 或加前缀处理。

误用空数组判断,忽略类型差异
很多人用 empty($arr) === false 或 count($arr) > 0 判断数组非空,但没意识到 empty([]) 返回 true,而 empty(null)、empty(false) 也返回 true,容易误判。更稳妥的方式是结合类型检查:is_array($arr) && !empty($arr)。若只关心是否为非空数组,推荐用 array_key_exists(0, $arr)(适用于索引数组)或直接 !empty($arr) && is_array($arr),避免把字符串 "0"、false 等误当作空数组处理。
混淆 array_merge() 与 '+' 合并行为
array_merge($a, $b) 会重置数字键并顺序合并,字符串键冲突时后者覆盖前者;而 $a + $b 是“左优先”合并,保留左数组的键值,右数组中同名键被忽略。例如:
$a = [0 => 'x', 'k' => 'a']; $b = [0 => 'y', 'k' => 'b', 1 => 'z'];
array_merge($a, $b) → [0=>'x', 1=>'a', 2=>'y', 3=>'b', 4=>'z']
$a + $b → [0=>'x', 'k'=>'a', 1=>'z']
需按语义选:要拼接索引数组用 array_merge;要保留默认配置+覆盖扩展项,用 + 更安全。
遍历时修改数组导致 key 错乱或跳过元素
在 foreach ($arr as $k => $v) 中直接对 $arr[$k] 赋值一般没问题,但若用 unset() 删除当前 key 或用 array_push() 新增元素,可能引发意外——PHP 内部指针可能跳过下一个元素,或新键不被本轮遍历捕获。正确做法:
• 删除操作改用 array_filter() 或先收集待删 key,循环结束后统一 unset
• 新增数据建议另建数组累积,最后合并
• 真需边遍历边改,改用 for ($i = 0; $i 并手动控制索引
忽视关联数组键的隐式类型转换
PHP 会把字符串数字键(如 '1'、'01')和整型键(1、01)视为相同,导致意外覆盖:
$arr['1'] = 'a'; $arr[1] = 'b'; // 实际只剩 $arr[1] => 'b'
同样,json_decode($json, true) 返回的数组若原始 JSON 键为数字字符串,PHP 会自动转为整型键,破坏原始结构。若需严格保键类型,应:
• 使用 stdClass 对象代替数组接收 JSON
• 或对 key 做预处理,如加前缀:$arr['k_'. $key] = $value
• 遍历时用 array_keys($arr, null, true)(第三个参数 true 表示严格比较)辅助识别原始键类型










