概述
正则表达式中的三种量词:Greedy 数量词、Reluctant 数量词较容易理解,对于Possessive 数量词,查到的解释是:Possessive和Greedy的匹配方式一样,先把整个字符串吞下,然后匹配整个字符串,如果匹配,就认为匹配,如果不匹配,就认为整个字符串不匹配,它不会从右端吐出一个字符串再进行匹配,只进行一次,这个解释有点模糊。代码测试如下:
public static void test4(){ String text = "a====b=========b"; String reg = "a.*+b"; Pattern p = Pattern.compile(reg); Matcher m = p.matcher(text); while (m.find()) { System.out.println(m.group(0)); } //无输出 } public static void test5(){ String text = "a====b=========b"; String reg = "a.*+"; Pattern p = Pattern.compile(reg); Matcher m = p.matcher(text); while (m.find()) { System.out.println(m.group(0)); } //输出整个字符串"a====b=========b" }
个人理解是先使用a.*+部分去匹配整个字符串,忽略后面的正则,如果成功则成功,否则失败,因此使用Possessive 数量词时后面不能再跟其他的正则,这个理解不知道是否正确。
转载于:https://www.cnblogs.com/kaqike/archive/2012/08/30/2663247.html
最后
以上就是贪玩蜻蜓为你收集整理的Java正则表达式 Possessive 数量词的理解的全部内容,希望文章能够帮你解决Java正则表达式 Possessive 数量词的理解所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复