Bagikan melalui


CA1875: Gunakan 'Regex.Count'

Harta benda Nilai
Identifikasi Aturan CA1875
Title Gunakan Regex.Count
Kategori Kinerja
Perbaikan bersifat merusak atau tidak merusak Non-breaking
Diaktifkan secara default di .NET 10 Sebagai saran

Penyebab

Count Properti dari MatchCollection digunakan Regex.Matches untuk mendapatkan jumlah kecocokan.

Deskripsi aturan

Regex.Count lebih sederhana dan lebih cepat daripada Regex.Matches(...).Count. Metode Count() ini dioptimalkan untuk menghitung kecocokan tanpa mewujudkan penuh MatchCollection. Memanggil Matches() lalu mengakses .Count melakukan pekerjaan yang tidak perlu yang dapat memengaruhi performa.

Cara memperbaiki pelanggaran

Ganti panggilan ke Regex.Matches(...).Count dengan Regex.Count(...).

Perbaikan kode yang secara otomatis melakukan transformasi ini tersedia.

Example

Cuplikan kode berikut menunjukkan pelanggaran CA1875:

using System.Text.RegularExpressions;

class Example
{
    public int CountWords(string text)
    {
        // Violation
        return Regex.Matches(text, @"\b\w+\b").Count;
    }
}
Imports System.Text.RegularExpressions

Class Example
    Public Function CountWords(text As String) As Integer
        ' Violation
        Return Regex.Matches(text, "\b\w+\b").Count
    End Function
End Class

Cuplikan kode berikut memperbaiki pelanggaran:

using System.Text.RegularExpressions;

class Example
{
    public int CountWords(string text)
    {
        // Fixed
        return Regex.Count(text, @"\b\w+\b");
    }
}
Imports System.Text.RegularExpressions

Class Example
    Public Function CountWords(text As String) As Integer
        ' Fixed
        Return Regex.Count(text, "\b\w+\b")
    End Function
End Class

Kapan harus menekan peringatan

Aman untuk menekan peringatan dari aturan ini jika performa tidak menjadi perhatian atau jika Anda menargetkan versi .NET yang tidak disertakan Regex.Count (sebelum .NET 7).

Menyembunyikan peringatan

Jika Anda hanya ingin menyembunyikan satu pelanggaran, tambahkan arahan praprosedur ke file sumber Anda untuk dinonaktifkan lalu aktifkan kembali aturannya.

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

Untuk menonaktifkan aturan untuk file, folder, atau proyek, atur tingkat keparahannya ke none dalam file konfigurasi.

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

Untuk informasi selengkapnya, lihat Cara menyembunyikan peringatan analisis kode.

Lihat juga