Heim  >  Artikel  >  Java  >  Vergleichsmuster für reguläre Java-Ausdrücke (gierig, widerstrebend, besitzergreifend)

Vergleichsmuster für reguläre Java-Ausdrücke (gierig, widerstrebend, besitzergreifend)

高洛峰
高洛峰Original
2017-01-09 16:19:101511Durchsuche

Gierigkeit (gieriger Typ): Maximale Übereinstimmung

X?, X*, X+, X{n,} ist die maximale Übereinstimmung. Wenn Sie beispielsweise „618b16d23a3ddab818f44e3be2c27e38“ verwenden möchten, um mit „aa34de1251f0d9fe1e645927f19a896e8aava fd273fcf5bcad3dfdad3c41bd81ad3e5abb“ übereinzustimmen, erwarten Sie möglicherweise, dass das Ergebnis mit „a34de1251f0d9fe1e645927f19a896e8“ übereinstimmt Das Ergebnis stimmt überein. Gehen Sie zu „a34de1251f0d9fe1e645927f19a896e8aava fd273fcf5bcad3dfdad3c41bd81ad3e5“.

Im Greediness-Modus wird versucht, einen möglichst großen Bereich abzugleichen, bis der gesamte Inhalt übereinstimmt. Zu diesem Zeitpunkt, wann Wenn festgestellt wird, dass die Übereinstimmung nicht erfolgreich sein kann, wird der Übereinstimmungsbereich ein wenig kleiner, bis die Übereinstimmung erfolgreich ist.

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

Ausgabe: a### abb

Reluctant (Faulheit) (Reluctant Type): Mindestübereinstimmung
X??, Match

Im Reluctant-Modus wird kein Versuch mehr unternommen, solange die Übereinstimmung erfolgreich ist um einen größeren Bereich von Inhalten abzugleichen

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

Ausgabe: a###aava ###abb

Im Gegensatz zu Greediness wird der Inhalt im Reluctant-Modus zweimal abgeglichen

Possessiv (Possessiv): Genaue Übereinstimmung
X?+, X*+, X++, X {n, }+ ist eine vollständige Übereinstimmung. Das Hinzufügen von + wird zu einer vollständigen Übereinstimmung

Der Possessive-Modus hat eine gewisse Ähnlichkeit mit Greediness, das heißt, er versucht, den größten Bereich an Inhalten bis zum Ende des Inhalts abzugleichen, aber im Gegensatz zu Greediness beschränkt sich der exakte Abgleich nicht mehr auf den Versuch, einen kleineren Bereich abzugleichen

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, "###"));

Ausgabe: aa34de1251f0d9fe1e645927f19a896e8aava 5194ba175fd9c71e9a9f6e68244d73a8abb

Für weitere Java-Übereinstimmungsmuster für reguläre Ausdrücke (gierig, widerstrebend, Possessivartikel) beachten Sie bitte die chinesische PHP-Website


Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn