String.matches() 정규식 이상: 숨겨진 정규식 함정 공개
Java 프로그래밍에서 String.matches() 메서드는 다음과 같습니다. 정규식에 대해 문자열의 유효성을 검사하는 직관적인 방법입니다. 그러나 그 동작은 특히 다른 프로그래밍 언어와 비교할 때 혼란스러울 수 있습니다.
다음 코드 조각을 고려하십시오.
String[] words = {"{apf","hum_","dkoe","12f"}; for(String s:words) { if(s.matches("[a-z]")) { System.out.println(s); } }
이 코드는 문자열 "dkoe"만 인쇄하기 위한 것입니다. 여기에는 소문자 알파벳 문자만 포함됩니다. 그러나 놀랍게도 아무것도 인쇄되지 않습니다! 왜 그럴까요?
문제의 핵심은 String.matches() 메서드의 특성에 있습니다. 다른 언어의 유사한 방법과 달리 match()는 전체 입력 문자열을 제공된 정규식과 일치시키려고 시도합니다. 즉, 전체 문자열이 패턴과 일치하는지 확인합니다.
정규식 "[a-z]"는 단일 소문자 알파벳 문자와만 일치합니다. 입력 문자열에 소문자 하나만 포함되어 있지 않으므로 match() 메서드는 어떤 문자열과도 일치하는 항목을 찾지 못합니다.
이 문제를 해결하려면 다음 두 가지 접근 방식을 취할 수 있습니다.
접근 방식 1: 패턴 및 일치자 사용
Pattern p = Pattern.compile("[a-z]+"); Matcher m = p.matcher(inputString); if (m.find()) { // match found }
이 접근 방식은 패턴 및 일치자를 사용합니다. 입력 문자열에서 처음으로 일치하는 항목을 찾는 일치자입니다. 정규식 "[a-z] "는 하나 이상의 소문자 알파벳 문자와 일치하며, 이는 원하는 동작입니다.
접근 방식 2: 문자 클래스에 '' 추가
문자열에 소문자만 포함되어 있는지 확인하는 것과 같은 간단한 경우에는 정규식을 다음과 같이 수정할 수 있습니다. 다음은 다음과 같습니다.
if(s.matches("[a-z]+")) { // match found }
문자 클래스 "[a-z]"에 ''를 추가하면 정규식은 하나 이상의 소문자 알파벳 문자와 일치하여 문제를 효과적으로 해결합니다.
String.matches()의 독특한 동작과 제공된 대안을 활용하면 이러한 일반적인 함정을 피하고 Java의 정규 표현식에 대해 문자열을 효과적으로 확인할 수 있습니다.
위 내용은 \'[a-z]\'와 같은 간단한 정규식을 사용할 때 Java의 String.matches() 메서드가 여러 개의 소문자를 포함하는 문자열을 일치시키지 못하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!