admin管理员组文章数量:1579086
1. Greedy:按最大限度检索,若不匹配则抛出一个字符一直到匹配为止。
如:
Pattern p = Patternpile("(.{3,10})[0-9]");
String s = "aadss1237a";
Matcher m = p.matcher(s);
if(m.find())
System.out.println(m.start() + "-" + m.end());
else
System.out.println("not match!");
第一次就吞10个字符,即"aadss1237a" 检查不匹配,吐出字符继续检查。直到吐出数字7.所以输出结果为:0-9
2. Reluctant: 按最小限度检索,若不匹配则添加一个字符直到匹配为止。
还是上面的代码:
Pattern p = Patternpile("(.{3,10}?)[0-9]");
String s = "aadss1237a";
Matcher m = p.matcher(s);
if(m.find())
System.out.println(m.start() + "-" + m.end());
else
System.out.println("not match!");
第一次吞入3个字符,即"aad". 检查不匹配,依次吃进s,s,1.才算匹配。所以输出结果为:0-6
3. Possessive:占用匹配,和Greedy 很像但是不会往外抛出字符,一次性检索若不匹配就结束。
这种情况用的很少,一般在追求效率的场合使用。以上代码显然不匹配,输出结果:not match!
若在String 后面加一个数字则可匹配。效率很高。
如: Pattern p = Patternpile("(.{3,10}+)[0-9]");
String s = "aadss1237a5";
Matcher m = p.matcher(s);
if(m.find())
System.out.println(m.start() + "-" + m.end());
else
System.out.println("not match!");
输出:0-11
本文标签: 正则表达式greedyReluctantPossessive
版权声明:本文标题:GreedyReluctantPossessive 正则表达式 内容由热心网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:https://www.elefans.com/dongtai/1727844924a1132975.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论