這次帶給大家正規的三種模式(貪婪型、勉強型、佔有型)詳解,使用正規三種模式(貪婪型、勉強型、佔有型)的注意事項有哪些,下面就是實戰案例,一起來看一下。
Greediness(貪婪型):最大匹配
X?、X*、X+、X{n,} 是最大匹配。例如你要用“<.+>” 去匹配“a
在Greediness 的模式下,會盡量大範圍的匹配,直到匹配了整個內容,這時發現匹配不能成功時,開始回退縮小匹配範圍,直到匹配成功
String test = "a<tr>aava </tr>abb "; String reg = "<.+>"; System.out.println(test.replaceAll(reg, "###"));
輸出:a
abb
Reluctant(Laziness)(勉強型):最小匹配
String test = "a<tr>aava </tr>abb "; String reg = "<.+?>"; System.out.println(test.replaceAll(reg, "###"));
aava
abb與Greediness 不同,Reluctant 模式下匹配了兩次內容
Possessive(佔有型):完全匹配
#Possessive 模式與Greediness 有一定的相似性,那就是都盡量匹配最大範圍的內容,直到內容結束,但與Greediness 不同的是,完全匹配不再回退嘗試匹配更小的範圍。 #
String test = "a<tr>aava </tr>abb "; String reg = "<.++>"; String test2 = "<tr>"; String reg2 = "<tr>"; System.out.println(test.replaceAll(reg, "###")); System.out.println(test2.replaceAll(reg2, "###"));
推薦閱讀:
在linux裡使用正規表示式詳解 ######################################################################### ###以上是正規的三種模式(貪婪型、勉強型、佔有型)詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!