不能用 array_sum() 判断字符串长度,因为它只接受数组参数,传入字符串会警告并返回0;str_split() 后求和得到的是ASCII值之和而非长度;正确方法是根据编码选择 strlen() 或 mb_strlen()。

为什么不能用 array_sum() 判断字符串长度
因为 array_sum() 是对数组元素求和的函数,它根本不接受字符串参数。直接传字符串会触发警告(Warning: array_sum() expects parameter 1 to be array, string given),返回 0 —— 这个结果既不是长度,也不可靠。
有人误以为把字符串转成数组再求和能“等效测长”,比如:array_sum(str_split('abc')),但这是错的:它实际算的是字符的 ASCII 值之和('a' + 'b' + 'c' = 97 + 98 + 99 = 294),和长度 3 完全无关。
strlen() 和 mb_strlen() 才是正解
PHP 原生提供两个专用于测长的函数,选哪个取决于字符串编码:
-
strlen()按字节计数,适合纯 ASCII 或已知单字节编码(如 latin1) -
mb_strlen()按字符计数,支持 UTF-8、GBK 等多字节编码,处理中文、emoji 必须用它 - 如果没启用
mbstring扩展,调用mb_strlen()会报致命错误Fatal error: Uncaught Error: Call to undefined function mb_strlen()
示例对比:
立即学习“PHP免费学习笔记(深入)”;
echo strlen('你好'); // 输出 6(UTF-8 下每个汉字占 3 字节)
echo mb_strlen('你好'); // 输出 2(正确字符数)
别把 str_split() + count() 当替代方案
虽然 count(str_split($str)) 确实能返回字符数,但它有明显缺陷:
- 创建了完整副本数组,内存开销大,字符串稍长(比如 1MB)就可能 OOM
- 对 UTF-8 多字节字符默认按字节切分,
str_split('??', 1)可能切出乱码或截断 emoji - 性能差:比
mb_strlen()慢 5–10 倍(实测万次调用)
除非你明确需要后续逐字符操作,否则只为“知道多长”而调用 str_split(),纯属绕路。
真正需要“数组求和逻辑”的场景在哪
如果你看到别人用 array_sum() 和字符串长度扯上关系,大概率是混淆了以下真实需求:
- 统计字符串中某类字符数量,比如数字个数:
array_sum(array_map(fn($c) => is_numeric($c), str_split($str))) - 计算 ASCII 值总和(极少见,如简单校验):
array_sum(array_map('ord', str_split($str))) - 对已拆分成数值数组的字段求和(和字符串长度完全无关):
array_sum([1, 2, 3])
这些都不是“用 array_sum 测长”,而是用它处理数字型数据——别让函数名里的 “sum” 误导你去强行套用。
字符串长度是个基础操作,用错函数不会报错但结果荒谬;尤其在处理用户输入、国际化内容时,mb_strlen() 的缺失常导致前端截断异常或数据库存储失败,这点比性能更值得警惕。











