会覆盖。PHP关联数组中重复下标(无论数字、字符串或转换后相同)均以后赋值为准,无警告;数字键会隐式转换(如"1"、1.9→1),字符串键严格区分大小写及空白字符;需手动检查或封装类防止覆盖。

会覆盖。PHP 关联数组(包括字符串键和数字键)中,如果重复声明同一个下标,后赋的值会直接覆盖前面的值,没有警告、错误或自动合并。
重复数字下标会被强制转换并覆盖
当使用纯数字字符串(如 "1")、浮点数(如 1.9)或负数作为键时,PHP 会按规则转换:浮点转整、负数保留、前导零字符串被当作整数处理(如 "01" → 1)。一旦转换后键相同,就发生覆盖。
-
$arr[1] = 'a'; $arr["1"] = 'b';→ 最终$arr[1]是'b' -
$arr[1.9] = 'x'; $arr[1] = 'y';→1.9转为1,被'y'覆盖 -
$arr[-5] = 'm'; $arr["-5"] = 'n';→ 两者等价,后者覆盖前者
重复字符串下标严格区分大小写但不报错
字符串键完全按字面匹配,"Key" 和 "key" 是两个不同键;但若两次写成一模一样的字符串(含空格、不可见字符),就会覆盖。常见坑是复制粘贴导致隐藏字符(如 "id " 和 "id")表面一样,实际键不同。
-
$data["id"] = 100; $data["id"] = 200;→$data["id"]最终是200 -
$data["status"] = "active"; $data["status "] = "pending";→ 这是两个键,不会覆盖(注意末尾空格) - 用
var_dump(array_keys($data))可验证键的真实值,避免肉眼误判
想避免覆盖?得手动检查或改用其他结构
PHP 原生不提供“禁止覆盖”模式。如果业务上需要拒绝重复键(比如配置项注册、路由定义),必须自己加防护逻辑。
立即学习“PHP免费学习笔记(深入)”;
- 插入前用
array_key_exists($key, $arr)或isset($arr[$key])判断(注意isset对null值返回false) - 用
+$arr合并数组时,右侧同名键会覆盖左侧——这不是“追加”,而是覆盖优先的合并 - 真要存多值,改用二维结构:
$map[$key][] = $value;,这样每个键对应一个数组 - 若需强约束,可封装成类,
set($key, $val)方法内部抛异常或记录 warning
最易忽略的是数字键的隐式类型转换——看着写了不同形式的下标,其实 PHP 已悄悄当成同一个整数处理了。调试时别只看 print_r,得用 var_dump 看键的原始类型。











