정규식 퍼즐: String.matches()가 오작동하는 이유는 무엇입니까?
다음 코드 조각에서 목표는 정규식을 사용하여 다음을 수행하는 것입니다. 소문자만 포함된 단어를 식별합니다.
String[] words = {"{apf","hum_","dkoe","12f"}; for(String s:words) { if(s.matches("[a-z]")) { System.out.println(s); } }
그러나 인쇄하는 대신 예상된 결과인 "dkoe"가 발생하면 코드는 출력을 생성하지 않습니다. 왜 이런 일이 발생하는 걸까요?
String.matches()의 함정
범인은 String.matches() 메서드를 오해하는 데 있습니다. 다른 언어의 유사해 보이는 것과 달리 Java의 match()는 전체 입력 문자열을 제공된 정규식과 일치시키려고 시도합니다. 이는 표현식이 문자열의 일부가 아닌 전체 문자열과 일치해야 함을 의미합니다.
주어진 코드에서 정규식 [a-z]는 단일 소문자와 일치합니다. 따라서 match()가 true를 반환하려면 전체 입력 문자열이 정확히 하나의 소문자로 구성되어야 합니다. 그러나 입력된 단어 중 이 조건을 만족하는 단어가 없습니다.
해결책: Pattern 및 Matcher 소개
이 문제를 해결하려면 Pattern 및 Matcher 개체를 사용하는 것이 좋습니다. 정규식 일치에 더 많은 제어와 유연성을 제공합니다.
Pattern p = Pattern.compile("[a-z]+"); Matcher m = p.matcher(inputstring); if (m.find()) // match found
문자 클래스 내에서 수량자를 사용하여 표현식이 하나 이상의 소문자를 포함하는 문자열과 일치하는지 확인하여 "dkoe"라는 단어를 올바르게 식별합니다.
위 내용은 Java의 `String.matches()`가 소문자 단어를 찾지 못하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!