Greediness(貪婪型):最大匹配
X?、X*、X+、X{n,} 是最大匹配。例如你要用 “.+>” 去匹配 “atr>aava /tr>abb”,也許你所期待的結(jié)果是想匹配 “tr>”,但是實(shí)際結(jié)果卻會(huì)匹配到 “tr>aava /tr>。
在 Greediness 的模式下,會(huì)盡量大范圍的匹配,直到匹配了整個(gè)內(nèi)容,這時(shí)發(fā)現(xiàn)匹配不能成功時(shí),開始回退縮小匹配范圍,直到匹配成功
String test = "atr>aava /tr>abb "; String reg = ".+>"; System.out.println(test.replaceAll(reg, "###"));
輸出:a###abb
Reluctant(Laziness)(勉強(qiáng)型):最小匹配
X??、X*?、X+?、X{n,}? 是最小匹配,其實(shí)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
標(biāo)簽:大興安嶺 常州 湖州 涼山 泰安 哈密 本溪
巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Java 正則表達(dá)式匹配模式(貪婪型、勉強(qiáng)型、占有型)》,本文關(guān)鍵詞 Java,正則,表達(dá)式,匹配,模式,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。