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 数量词时后面不能再跟其他的正则,这个理解不知道是否正确。

 

posted @ 2012-08-30 10:44  kaqike  阅读(605)  评论(1编辑  收藏  举报