Java正则表达式 Possessive 数量词的理解
正则表达式中的三种量词: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 数量词时后面不能再跟其他的正则,这个理解不知道是否正确。