正则表达式:贪婪模式与懒惰模式

前端之家收集整理的这篇文章主要介绍了正则表达式:贪婪模式与懒惰模式前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

一 语法区别

贪婪模式与懒惰模式的语法区别在于重复限定修饰符的后面是否有问号,有的话就是懒惰模式,否则就是贪婪模式。

二 例子

他所说的应该是贪婪量词,是先吃尽所有字符,然后再一个一个地吐出来,直接匹配成功为止
而懒惰量词,是从头开始一个字符一个字符地吃,直接匹配成功为止

我想其意思应该是贫婪是逐渐向前匹配,而懒惰是向后慢慢匹配吧

贪婪和懒惰的匹配过程是这样的:

懒惰是从左边一个一个地吃直到匹配为止,不加 ? 的是一口吃掉整个字符串,然后从最后一个一个地吐出来直到匹配为止

字符串
a=====b=====b===

a.*b 将匹配满足条件最长的字符串 a=====b=====b

工作方式:
首先将:a=====b=====b=== 全部吃掉,从右边一个一个地吐出来

1. a=====b=====b=== 不匹配,吐出一字符
2. a=====b=====b== 不匹配,再吐出一字符
3. a=====b=====b= 不匹配,再吐出一字符
4. a=====b=====b 匹配了,结束。如果再不匹配继续吐,直到没有字符了,匹配失败

a.*? 将匹配满足条件最短的字符串 a=====b

工作方式:
从左边一个一个地吃掉字符
1. a 不能匹配表达式,继续吃
2. a= 不能匹配表达式,继续吃
3. a== 不能匹配表达式,继续吃
4. a=== 不能匹配表达式,继续吃
5. a==== 不能匹配表达式,继续吃
6. a===== 不能匹配表达式,继续吃
7. a=====b 呵呵,终于能匹配表达式了,匹配结束,匹配位置留于字符 b 后面,继续其他的匹配。如果不能匹配则一个一个地吃掉整个字符串直到吃完为止若还没有匹配则匹配失败。

3 参考URL:http://topic.csdn.net/u/20090917/17/ce6ec06c-2a3e-422f-88b8-40946e558c26.html

原文链接:https://www.f2er.com/regex/361501.html

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