首頁  >  文章  >  web前端  >  正規的三種模式(貪婪型、勉強型、佔有型)詳解

正規的三種模式(貪婪型、勉強型、佔有型)詳解

php中世界最好的语言
php中世界最好的语言原創
2018-03-30 11:26:392476瀏覽

這次帶給大家正規的三種模式(貪婪型、勉強型、佔有型)詳解,使用正規三種模式(貪婪型、勉強型、佔有型)的注意事項有哪些,下面就是實戰案例,一起來看一下。

Greediness(貪婪型):最大匹配

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

在Greediness 的模式下,會盡量大範圍的匹配,直到匹配了整個內容,這時發現匹配不能成功時,開始回退縮小匹配範圍,直到匹配成功

String test = "a<tr>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 }?有些多餘。只要匹配成功,就不再繼續嘗試匹配更大範圍的內容

String test = "a<tr>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 = "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, "###"));
輸出:aaava abb

相信看了本文案例你已經掌握了方法,更多精彩請關注php中文網其它相關文章!

推薦閱讀:

在linux裡使用正規表示式詳解



######################################################################### ###

以上是正規的三種模式(貪婪型、勉強型、佔有型)詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn