本篇內容介紹了“Java正則表達式匹配模式的用法”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!
Greediness(貪婪型):較大匹配
X?、X*、X+、X{n,} 是較大匹配。例如你要用 “<.+>” 去匹配 “a
在 Greediness 的模式下,會盡量大范圍的匹配,直到匹配了整個內容,這時發現匹配不能成功時,開始回退縮小匹配范圍,直到匹配成功
String test = "aaava 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 = "aaava 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 = "aaava abb "; String reg = "<.++>"; String test2 = ""; String reg2 = " "; System.out.println(test.replaceAll(reg, "###")); System.out.println(test2.replaceAll(reg2, "###")); 輸出:a
aava abb“Java正則表達式匹配模式的用法”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注創新互聯網站,小編將為大家輸出更多高質量的實用文章!
本文題目:Java正則表達式匹配模式的用法-創新互聯
網頁網址:http://m.jcarcd.cn/article/cesced.html