微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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

我正在解析一些大的日志文件,并且有一些非常简单的字符串匹配

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

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

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

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

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

解决方法

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

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

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐