strrev()最快最安全但仅适用于ascii/latin-1;utf-8需自定义mb_strrev(),用mb_substr()逐字符反转,避免str_split或正则等低效错误方案。

用 strrev() 最快也最安全
PHP 内置的 strrev() 就是专干这事的,不依赖扩展、不挑编码(只要是非 UTF-8 多字节字符),执行快、语义清晰。它直接按字节反转,对纯 ASCII 或 Latin-1 字符串完全可靠。
- 输入必须是
string类型,传null或数组会触发警告 - 如果字符串含 UTF-8 中文、emoji,
strrev()会把多字节序列拆开,结果乱码——这不是 bug,是设计如此 - 别试图用
strrev()处理 JSON 字符串或带转义的文本,反转后结构必坏
UTF-8 字符串得用 mb_strrev()(但 PHP 没这函数)
PHP 标准库确实没提供多字节安全的反转函数,所以你得自己写一个轻量版,核心是用 mb_substr() 逐个提取字符再拼接:
function mb_strrev($str, $encoding = 'UTF-8') {
$len = mb_strlen($str, $encoding);
$rev = '';
for ($i = $len - 1; $i >= 0; $i--) {
$rev .= mb_substr($str, $i, 1, $encoding);
}
return $rev;
}- 必须显式传
$encoding,不能依赖mb_internal_encoding(),否则在 CLI 和 Web 环境下行为可能不一致 - 性能比
strrev()差一个数量级,长字符串(>10KB)要注意响应延迟 -
mb_substr($str, -1)不可靠,某些 PHP 版本对负偏移 + 多字节处理有边界问题,老老实实用for循环
别用 array_reverse() + implode() 做字符串反转
有人习惯 implode('', array_reverse(str_split($str))),看起来“函数式”,实际埋了三个坑:
-
str_split()默认按字节切分,UTF-8 下照样碎成乱码 - 大字符串会生成超长数组,内存占用翻倍,PHP 7.4+ 还可能触发
memory_limit报错 -
array_reverse()对关联数组键名不保留,虽然字符串转数组后键是数字,但这个组合本身语义错位,读代码的人第一反应是“你在反转什么数组?”
正则或 preg_replace() 不适合做反转
网上有些用 preg_replace('/(.)(?=(.*))/u', '$2$1', $str) 的奇技淫巧,纯属炫技:
立即学习“PHP免费学习笔记(深入)”;
- PCRE 回溯深度限制会让稍长字符串直接返回
null或空字符串 - 正则引擎不是为字符串操作设计的,
/u模式下性能极差,且无法控制编码检测逻辑 - 这种写法在 PHP 8.1+ 的 JIT 编译下反而更慢,因为正则优化路径和字符串原生操作完全不重合
真正要处理的是字符顺序,不是模式匹配。工具用错,问题只会从一个地方挪到另一个地方。











