我正在解析一些大的日志文件,并且有一些非常简单的字符串匹配
if(m/Some String Pattern/o){ #Do something }
这看起来很简单,但事实上我所拥有的大部分比赛都可以对阵线的起点,但比赛将会"更长",例如
if(m/^Initial static string that matches Some String Pattern/o){ #Do something }
显然这是一个更长的正则表达式,因此需要更多工作来匹配.但是我可以使用行锚的开头,这将允许表达式作为失败的匹配更快地被丢弃.
我的预感是后者会更有效率.任何人都可以支持我/击落我:-)
我想你会发现用^开始你的正则表达式肯定会更快,因为正则表达式引擎不需要查看字符串左边缘的任何进一步匹配.
当然,这是你可以轻松测试和测量的东西.做一个正则表达式匹配1000万次左右,衡量它需要多长时间,然后再尝试使用不同的正则表达式.