Regex-Rätsel: Warum verhält sich String.matches() schlecht?
Im folgenden Codeausschnitt besteht das Ziel darin, reguläre Ausdrücke zu verwenden Identifizieren Sie Wörter, die nur Kleinbuchstaben enthalten:
String[] words = {"{apf","hum_","dkoe","12f"}; for(String s:words) { if(s.matches("[a-z]")) { System.out.println(s); } }
Anstatt jedoch „dkoe“ zu drucken, was erwartet wird Ergebnis: Der Code erzeugt keine Ausgabe. Warum passiert das?
Die Fallstricke von String.matches()
Der Schuldige liegt im Missverständnis der String.matches()-Methode. Im Gegensatz zu seinen scheinbar ähnlichen Gegenstücken in anderen Sprachen versucht matches() in Java, die gesamte Eingabezeichenfolge mit dem bereitgestellten regulären Ausdruck abzugleichen. Das bedeutet, dass der Ausdruck mit der gesamten Zeichenfolge übereinstimmen muss, nicht nur mit einem Teil davon.
Im angegebenen Code entspricht der reguläre Ausdruck [a-z] jedem einzelnen Kleinbuchstaben. Damit „matches()“ „true“ zurückgibt, muss die gesamte Eingabezeichenfolge aus genau einem Kleinbuchstaben bestehen. Allerdings erfüllt keines der Eingabewörter diese Bedingung.
Die Lösung: Einführung von Pattern und Matcher
Um dieses Problem zu beheben, wird empfohlen, Pattern- und Matcher-Objekte zu verwenden. die mehr Kontrolle und Flexibilität beim Regex-Abgleich bieten:
Pattern p = Pattern.compile("[a-z]+"); Matcher m = p.matcher(inputstring); if (m.find()) // match found
Durch die Verwendung des Quantifizierers innerhalb der Zeichenklasse stellen wir sicher, dass der Ausdruck mit Zeichenfolgen übereinstimmt enthält ein oder mehrere Kleinbuchstaben, die das Wort „dkoe“ korrekt identifizieren.
Das obige ist der detaillierte Inhalt vonWarum findet Javas „String.matches()' keine kleingeschriebenen Wörter?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!