>Java >java지도 시간 >Java의 `String.matches()`가 소문자 단어를 찾지 못하는 이유는 무엇입니까?

Java의 `String.matches()`가 소문자 단어를 찾지 못하는 이유는 무엇입니까?

Susan Sarandon
Susan Sarandon원래의
2024-11-25 17:56:11877검색

Why Does Java's `String.matches()` Fail to Find Lowercase Words?

정규식 퍼즐: 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.