正则表达式--贪婪与懒惰
来源:互联网 发布:美国mba 知乎 编辑:程序博客网 时间:2024/06/10 08:55
当正则表达式中包含能接受重复的限定符时,通常的行为是(在使整个表达式能得到匹配的前提下)匹配尽可能多的字符。考虑这个表达式:a.*b,它将会匹配最长的以a开始,以b结束的字符串。如果用它来搜索aabab的话,它会匹配整个字符串aabab。这被称为贪婪匹配。
有时,我们更需要懒惰匹配,也就是匹配尽可能少的字符。前面给出的限定符都可以被转化为懒惰匹配模式,只要在它后面加上一个问号?。这样.*?就意味着匹配任意数量的重复,但是在能使整个匹配成功的前提下使用最少的重复。现在看看懒惰版的例子吧:
a.*?b匹配最短的,以a开始,以b结束的字符串。如果把它应用于aabab的话,它会匹配aab和ab(为什么第一个匹配是aab而不是ab?简单地说,因为正则表达式有另一条规则,比懒惰/贪婪规则的优先级更高:最先开始的区配最有最大的优先权——The Match That Begins Earliest Wins)。
- 正则表达式--贪婪与懒惰
- 贪婪与懒惰--正则表达式
- 正则表达式 贪婪与懒惰
- 正则表达式的贪婪与懒惰
- 正则表达式学习记录-贪婪与懒惰
- 正则表达式中的贪婪与懒惰
- 正则表达式中的贪婪与懒惰模式
- 正则表达式 懒惰匹配与贪婪匹配
- 正则表达式:贪婪模式与懒惰模式
- 正则表达式的贪婪与懒惰模式
- 正则表达式的贪婪与懒惰模式
- 正则表达式的贪婪与懒惰模式
- 正则表达中贪婪性与懒惰性表达式
- PHP正则表达式-贪婪与懒惰匹配
- PHP正则表达式-贪婪与懒惰匹配
- 贪婪模式与懒惰模式(正则表达式)
- (PHP)正则表达式-贪婪匹配与懒惰匹配的区别
- 正则表达式的贪婪匹配与懒惰匹配
- malloc 注意事项
- ISO9000-----扼杀软件企业的创新能力的杀手
- 正则表达式--注释
- Struts标签的简单总结
- 猜谜语(转的)
- 正则表达式--贪婪与懒惰
- 转:ASP.NET2.0的Membership中客户化用户密码的设置
- 正则表达式--处理选项
- .NET性能优化方面的总结
- 通用分页存储过程
- Linux下开发环境的搭建
- PHP学习中
- 正则表达式--还有些什么东西没提到
- AJAX实例:根据邮编自动完成地址信息