正则表达式 – 哪个更有效的正则表达式?

前端之家收集整理的这篇文章主要介绍了正则表达式 – 哪个更有效的正则表达式?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在解析一些大的日志文件,并且有一些非常简单的字符串匹配

if(m/Some String Pattern/o){
    #Do something
}

这看起来很简单,但事实上我所拥有的大部分比赛都可以对阵线的起点,但比赛将会“更长”,例如

if(m/^Initial static string that matches Some String Pattern/o){
    #Do something
}

显然这是一个更长的正则表达式,因此需要更多工作来匹配.但是我可以使用行锚的开头,这将允许表达式作为失败的匹配更快地被丢弃.

我的预感是后者会更有效率.任何人都可以支持我/击落我:-)

解决方法

我想你会发现用^开始你的正则表达式肯定会更快,因为正则表达式引擎不需要查看字符串左边缘的任何进一步匹配.

当然,这是你可以轻松测试和测量的东西.做一个正则表达式匹配1000万次左右,衡量它需要多长时间,然后再尝试使用不同的正则表达式.

猜你在找的正则表达式相关文章