共用方式為


CA1874:使用 'Regex.IsMatch'

房產 價值觀
規則識別碼 CA1874
標題 使用 Regex.IsMatch
類別 效能
修正是破壞性或非破壞性 Non-breaking
在 .NET 10 中預設啟用 建議

原因

Success result from Regex.Match 的屬性可用來檢查模式是否相符。

規則描述

Regex.IsMatchRegex.Match(...).Success更簡單、更快速。 此 IsMatch 方法針對您只需要知道是否存在相符項的情況進行了最佳化,而不是相符項是什麼。 呼叫然後檢查SuccessMatch()執行不必要的工作,這可能會影響效能。

如何修正違規

將對 的 Regex.Match(...).Success 呼叫取代為 Regex.IsMatch(...)

可以使用自動執行此轉換的 程式碼修正程式

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

若要停用檔案、資料夾或項目的規則,請在組態檔中將其嚴重性設為

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

如需詳細資訊,請參閱 如何隱藏程式碼分析警告

另請參閱