다음을 통해 공유


CA1874: 'Regex.IsMatch' 사용

재산 가치
규칙 아이디 CA1874
Title Regex.IsMatch 사용
범주 성능
수정 사항이 문제를 해결하고 있는지 혹은 새로운 문제를 일으키지 않는지 여부 Non-breaking
.NET 10에서 기본적으로 사용하도록 설정 제안 사항

원인

결과 Regex.Match 속성은 Success 패턴이 일치하는지 확인하는 데 사용됩니다.

규칙 설명

Regex.IsMatch 보다 간단하고 빠릅니다 Regex.Match(...).Success. 이 IsMatch 메서드는 일치 항목이 무엇인지가 아니라 일치하는 항목이 있는지 여부만 알아야 하는 경우에 최적화됩니다. 호출 Match() 및 확인은 성능에 Success 영향을 미칠 수 있는 불필요한 작업을 수행합니다.

위반을 해결하는 방법

호출을 .로 Regex.IsMatch(...)바꾸기 Regex.Match(...).Success

이 변환을 자동으로 수행하는 코드 수정 을 사용할 수 있습니다.

Example

다음 코드 조각은 CA1874 위반을 보여줍니다.

using System.Text.RegularExpressions;

class Example
{
    public bool IsValidEmail(string email)
    {
        // Violation
        return Regex.Match(email, @"^[^@\s]+@[^@\s]+\.[^@\s]+$").Success;
    }
}
Imports System.Text.RegularExpressions

Class Example
    Public Function IsValidEmail(email As String) As Boolean
        ' Violation
        Return Regex.Match(email, "^[^@\s]+@[^@\s]+\.[^@\s]+$").Success
    End Function
End Class

다음 코드 조각은 위반을 해결합니다.

using System.Text.RegularExpressions;

class Example
{
    public bool IsValidEmail(string email)
    {
        // Fixed
        return Regex.IsMatch(email, @"^[^@\s]+@[^@\s]+\.[^@\s]+$");
    }
}
Imports System.Text.RegularExpressions

Class Example
    Public Function IsValidEmail(email As String) As Boolean
        ' Fixed
        Return Regex.IsMatch(email, "^[^@\s]+@[^@\s]+\.[^@\s]+$")
    End Function
End Class

경고를 표시하지 않는 경우

성능이 중요하지 않은 경우 이 규칙에서 경고를 표시하지 않는 것이 안전합니다.

경고 표시 안 함

단일 위반을 억제하려면, 소스 파일에 전처리기 지시문을 추가하여 규칙을 비활성화한 다음 다시 활성화하세요.

#pragma warning disable CA1874
// The code that's violating the rule is on this line.
#pragma warning restore CA1874

파일, 폴더 또는 프로젝트에 대한 규칙을 비활성화하려면 none에서 해당 심각도를 로 설정하세요.

[*.{cs,vb}]
dotnet_diagnostic.CA1874.severity = none

자세한 내용은 코드 분석 경고를 표시하지 않는 방법을 참조하세요.

참고하십시오