当前位置:  开发笔记 > 编程语言 > 正文

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

如何解决《哪个更有效的正则表达式?》经验,为你挑选了1个好方法。

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

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

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

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

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

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



1> Greg Hewgill..:

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

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

推荐阅读
coco2冰冰
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有