完全没必要用 while 循环判断字符串长度,应直接使用 strlen() 或 mb_strlen():前者适用于纯 ASCII 字符串,后者用于含中文、emoji 等 UTF-8 多字节字符,手写循环既低效又易出错且 PHP 8+ 已禁用字符串下标访问。

PHP 中完全没必要用 while 循环判断字符串长度——strlen() 是标准、安全、高效的内置方案,手写循环既慢又易出错。
为什么不能靠 while 遍历计数来“测长”
手动遍历每个字符累加计数看似直观,但实际存在多个硬伤:
-
mb_strlen()才是处理中文、emoji 等多字节字符的正确方式;while配substr()或$str[$i]在 UTF-8 下极易截断字节,返回错误长度 - 每次循环都要做边界检查和索引递增,性能比
strlen()低一个数量级(尤其对长字符串) - PHP 8+ 已禁用对字符串使用
[]访问单字节(会触发Deprecated警告),while ($str[$i] !== '')这类写法在新版本直接报错
strlen() 和 mb_strlen() 怎么选
取决于你的字符串是否含非 ASCII 字符:
- 纯英文、数字、ASCII 符号 → 用
strlen()(快,C 层实现) - 含中文、日文、emoji、带重音字母(如 naïve)→ 必须用
mb_strlen($str, 'UTF-8') - 不确定来源?统一用
mb_strlen($str, 'UTF-8')更稳妥,开销可忽略
示例:
立即学习“PHP免费学习笔记(深入)”;
$str = "Hello 世界?"; echo strlen($str); // 输出 15(字节长度) echo mb_strlen($str, 'UTF-8'); // 输出 9(字符长度)
真要手写循环?至少避开这些坑
如果仅出于学习或特殊边界场景(如逐字节解析协议头),必须用循环,请严格按以下写:
- 用
for替代while,显式控制索引,避免无限循环风险 - 用
mb_substr($str, $i, 1, 'UTF-8')取单字符,而非$str[$i] - 提前用
mb_strlen($str, 'UTF-8')获取上限,作为for终止条件,不依赖“取到空字符”判断
错误示范(PHP 8+ 报错):
$i = 0;
while ($str[$i] !== '') { $i++; } // ❌ 不合法
勉强可用但不推荐的写法:
$len = 0;
for ($i = 0; mb_substr($str, $i, 1, 'UTF-8') !== ''; $i++) {
$len++;
}
真正需要“测长”时,别绕路。字符长度不是逻辑分支点,而是基础元数据——查就完了,用 strlen() 或 mb_strlen()。手写循环只在你要对每个字符做不可简化的操作时才有意义,而那已经不是“测长”,是“遍历处理”了。











