首页 > 代码库 > 正则表达式中的贪婪、惰性、支配性的量词

正则表达式中的贪婪、惰性、支配性的量词

转自:http://blog.csdn.net/cyai/article/details/2297951

 

使用正则表达式中的贪婪、惰性、支配性的量词可以控制表达式匹配过程,我们知道量词?、*、+的意义,可以指定相关模式出现的次数,默认的情况下我们使用 的是贪婪量词,它的匹配过程是从整个字符串开始查看,如果不匹配就去掉最后一个,再看看是否匹配,如此循环一直到匹配或字符串空为止,如:
var s = "abbbaabbbaaabbb1234";
var re1=/.*bbb/g;     //*是贪婪量词
re1.test(s);
这个匹配过程将从整个字符串开始:
re1.test("abbbaabbbaaabbb1234");   //false  ,则去掉最后一个字符4再继续
re1.test("abbbaabbbaaabbb123");   //false  ,则去掉最后一个字符3再继续
re1.test("abbbaabbbaaabbb12");   //false  ,则去掉最后一个字符2再继续
re1.test("abbbaabbbaaabbb1");   //false  ,则去掉最后一个字符1再继续
re1.test("abbbaabbbaaabbb");   //true ,结束

在贪婪量词的后面加多一个?就变成了惰性量词,它的匹配过程相反,是从前面第一个开始,不匹配则加一个,如此循环直到字符串结束,以上面的为例子。
var s = "abbbaabbbaaabbb1234";
var re1=/.*?bbb/g;     //*?是惰性量词
re1.test(s);
它的匹配过程如下:
re1.test("a");      //false,  再加一个
re1.test("ab");      //false,  再加一个
re1.test("abb");      //false,  再加一个
re1.test("abbb");      //true,  匹配了,保存这个结果,再从下一个开始
re1.test("a");      //false,  再加一个
re1.test("aa");      //false,  再加一个
re1.test("aab");      //false,  再加一个
re1.test("aabb");      //false,  再加一个
re1.test("aabbb");      //true,  匹配了,保存这个结果,再从下一个开始
......

支配性量词就是只检查整个字符串,很多浏览器不支持,故不再举例。

正则表达式中的贪婪、惰性、支配性的量词