主页 > 知识库 > Java 正则表达式匹配模式(贪婪型、勉强型、占有型)

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

热门标签:外呼系统无呼出路由是什么原因 400电话办理电话办理 ai电话机器人搭建 西藏智能外呼系统代理商 贵港公司如何申请400电话 甘肃医疗外呼系统排名 梅县地图标注 地图标注教学点 呼叫系统外呼只能两次

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种匹配模式小结

标签:大兴安岭 海口 常州 湖州 凉山 泰安 哈密 本溪

巨人网络通讯声明:本文标题《Java 正则表达式匹配模式(贪婪型、勉强型、占有型)》,本文关键词  Java,正则,表达式,匹配,模式,;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 下面列出与本文章《Java 正则表达式匹配模式(贪婪型、勉强型、占有型)》相关的同类信息!
  • 本页收集关于Java 正则表达式匹配模式(贪婪型、勉强型、占有型)的相关信息资讯供网民参考!
  • 企业400电话

    智能AI客服机器人
    15000

    在线订购

    合计11份范本:公司章程+合伙协议+出资协议+合作协议+股权转让协议+增资扩股协议+股权激励+股东会决议+董事会决议

    推荐文章