strrev仅支持单字节ASCII字符串反转,多字节字符(如中文)需用mb_substr循环或PHP 8.3+的mb_strrev;使用mb_*函数必须显式指定UTF-8编码,否则仍会乱码。

strrev 函数能直接反转字符串,但不支持多字节字符(如中文)
strrev 是 PHP 内置函数,作用就是把传入的字符串按字节倒序排列。它快、简单、无需额外扩展,但只适合 ASCII 场景。
比如 strrev("abc") 返回 "cba",没问题;但 strrev("你好") 会返回乱码——因为 UTF-8 中一个汉字占 3 字节,strrev 把字节顺序全打乱了,不是“字符级”反转。
中文或 Unicode 字符串必须用 mb_substr + 循环拼接
要安全反转含中文、日文、emoji 的字符串,得先用 mb_strlen 获取字符数,再用 mb_substr 从末尾逐个截取字符:
$str = "Hello 世界";
$len = mb_strlen($str, 'UTF-8');
$result = '';
for ($i = $len - 1; $i >= 0; $i--) {
$result .= mb_substr($str, $i, 1, 'UTF-8');
}
// $result === "界世 olleH"- 必须显式指定编码(如
'UTF-8'),否则mb_*函数可能退化为单字节行为 - 不能用
str_split或preg_split('//u')后array_reverse,前者在某些 PHP 版本中对 emoji 分割不稳定,后者正则开销大且易漏边界
PHP 8.3+ 可用 strrev 的多字节版本:mb_strrev(需启用 mbstring)
PHP 8.3 新增了 mb_strrev,是真正意义上的多字节安全反转函数,但注意:
- 它不是所有环境都可用——必须 PHP ≥ 8.3 且
mbstring扩展已加载 - 调用时仍需指定编码,例如
mb_strrev("?a", 'UTF-8') - 低于 8.3 的项目无法使用,别在生产环境硬切,容易报
Call to undefined function mb_strrev()
别用 array_reverse + str_split 做“伪多字节反转”
常见错误写法:implode('', array_reverse(str_split($str))) —— 这在中文里完全失效。str_split 按字节切分,"你好"(6 字节)会被切成 6 个乱码字节片段,再反转拼回去仍是乱码。
同理,preg_match_all('//u', $str, $matches) 虽然能匹配 Unicode 字符,但正则引擎在处理超长字符串或混合 emoji 时有性能抖动,且代码可读性差。
立即学习“PHP免费学习笔记(深入)”;
真正需要兼顾兼容性与正确性的场景,老老实实用 mb_substr 循环最稳。最容易被忽略的是:没传编码参数,或误以为 mb_internal_encoding() 已全局设置就不用再写了——它不会自动透传到每个 mb_* 函数调用里。











