濮阳杆衣贸易有限公司

主頁 > 知識庫 > Java 正則表達式匹配模式(貪婪型、勉強型、占有型)

Java 正則表達式匹配模式(貪婪型、勉強型、占有型)

熱門標簽:外呼系統(tǒng)無呼出路由是什么原因 400電話辦理電話辦理 ai電話機器人搭建 西藏智能外呼系統(tǒng)代理商 貴港公司如何申請400電話 甘肅醫(yī)療外呼系統(tǒng)排名 梅縣地圖標注 地圖標注教學點 呼叫系統(tǒng)外呼只能兩次

Greediness(貪婪型):最大匹配

X?、X*、X+、X{n,} 是最大匹配。例如你要用 “.+>” 去匹配 “atr>aava /tr>abb”,也許你所期待的結(jié)果是想匹配 “tr>”,但是實際結(jié)果卻會匹配到 “tr>aava /tr>。

在 Greediness 的模式下,會盡量大范圍的匹配,直到匹配了整個內(nèi)容,這時發(fā)現(xiàn)匹配不能成功時,開始回退縮小匹配范圍,直到匹配成功

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 的模式下,只要匹配成功,就不再繼續(xù)嘗試匹配更大范圍的內(nèi)容

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

輸出:a###aava ###abb

與 Greediness 不同,Reluctant 模式下匹配了兩次內(nèi)容

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

Possessive 模式與 Greediness 有一定的相似性,那就是都盡量匹配最大范圍的內(nèi)容,直到內(nèi)容結(jié)束,但與 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種匹配模式小結(jié)

標簽:大興安嶺 常州 湖州 涼山 泰安 哈密 本溪

巨人網(wǎng)絡(luò)通訊聲明:本文標題《Java 正則表達式匹配模式(貪婪型、勉強型、占有型)》,本文關(guān)鍵詞  Java,正則,表達式,匹配,模式,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Java 正則表達式匹配模式(貪婪型、勉強型、占有型)》相關(guān)的同類信息!
  • 本頁收集關(guān)于Java 正則表達式匹配模式(貪婪型、勉強型、占有型)的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    黑龙江省| 荆门市| 财经| 兴业县| 寿宁县| 浑源县| 太仓市| 峨边| 扶沟县| 奉节县| 垫江县| 乐至县| 昌黎县| 濮阳县| 玉门市| 陈巴尔虎旗| 收藏| 海口市| 信丰县| 清苑县| 临汾市| 枞阳县| 江门市| 闻喜县| 河池市| 泸水县| 深圳市| 五寨县| 资源县| 台江县| 蒙山县| 锡林浩特市| 聊城市| 鄂温| 奉新县| 芜湖市| 新沂市| 镇巴县| 苏尼特左旗| 井研县| 青川县|