我是靠谱客的博主 贪玩蜻蜓,最近开发中收集的这篇文章主要介绍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 数量词时后面不能再跟其他的正则,这个理解不知道是否正确。

 

转载于:https://www.cnblogs.com/kaqike/archive/2012/08/30/2663247.html

最后

以上就是贪玩蜻蜓为你收集整理的Java正则表达式 Possessive 数量词的理解的全部内容,希望文章能够帮你解决Java正则表达式 Possessive 数量词的理解所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(57)

评论列表共有 0 条评论

立即
投稿
返回
顶部