• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    Java 正则表达式匹配模式(贪婪型、勉强型、占有型)

    Greediness(贪婪型):最大匹配

    X?、X*、X+、X{n,} 是最大匹配。例如你要用 “.+>” 去匹配 “atr>aava /tr>abb”,也许你所期待的结果是想匹配 “tr>”,但是实际结果却会匹配到 “tr>aava /tr>。

    在 Greediness 的模式下,会尽量大范围的匹配,直到匹配了整个内容,这时发现匹配不能成功时,开始回退缩小匹配范围,直到匹配成功

    String test = "atr>aava /tr>abb ";
    String reg = ".+>";
    System.out.println(test.replaceAll(reg, "###"));

    输出:a###abb

    Reluctant(Laziness)(勉强型):最小匹配
    X??、X*?、X+?、X{n,}? 是最小匹配,其实X{n,m}?和X{n }?有些多余。在 Greediness 模式之后添加 ? 就成最小匹配。

    在 Reluctant 的模式下,只要匹配成功,就不再继续尝试匹配更大范围的内容

    String test = "atr>aava /tr>abb ";
    String reg = ".+?>";
    System.out.println(test.replaceAll(reg, "###"));

    输出:a###aava ###abb

    与 Greediness 不同,Reluctant 模式下匹配了两次内容

    Possessive(占有型):完全匹配
    X?+、X*+、X++、X{n,}+ 是完全匹配,在 Greediness 模式之后添加 + 就成完全匹配。

    Possessive 模式与 Greediness 有一定的相似性,那就是都尽量匹配最大范围的内容,直到内容结束,但与 Greediness 不同的是,完全匹配不再回退尝试匹配更小的范围。

    String test = "atr>aava /tr>abb ";
    String reg = ".++>";
    String test2 = "tr>";
    String reg2 = "tr>";
    System.out.println(test.replaceAll(reg, "###"));
    System.out.println(test2.replaceAll(reg2, "###"));

    输出:atr>aava /tr>abb

    您可能感兴趣的文章:
    • 正则表达式中最短匹配模式的用法浅析
    • JS中正则表达式全局匹配模式 /g用法详解
    • 正则表达式惰性匹配模式(?)
    • 正则表达式全局匹配模式(g修饰符)
    • 正则表达式常见的4种匹配模式小结
    上一篇:正则表达式小脚本(对输入内容进行处理)
    下一篇:js正则表达式实现数字每隔四位用空格分隔代码
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    Java 正则表达式匹配模式(贪婪型、勉强型、占有型) Java,正则,表达式,匹配,模式,