Catatan
Akses ke halaman ini memerlukan otorisasi. Anda dapat mencoba masuk atau mengubah direktori.
Akses ke halaman ini memerlukan otorisasi. Anda dapat mencoba mengubah direktori.
| Harta benda | Nilai |
|---|---|
| Identifikasi Aturan | CA1874 |
| Title | Gunakan Regex.IsMatch |
| Kategori | Kinerja |
| Perbaikan bersifat merusak atau tidak merusak | Non-breaking |
| Diaktifkan secara default di .NET 10 | Sebagai saran |
Penyebab
Properti Success hasil dari Regex.Match digunakan untuk memeriksa apakah pola cocok.
Deskripsi aturan
Regex.IsMatch lebih sederhana dan lebih cepat daripada Regex.Match(...).Success. Metode IsMatch ini dioptimalkan untuk kasus di mana Anda hanya perlu tahu apakah ada kecocokan, daripada apa kecocokannya. Memanggil Match() lalu memeriksa Success melakukan pekerjaan yang tidak perlu yang dapat memengaruhi performa.
Cara memperbaiki pelanggaran
Ganti panggilan ke Regex.Match(...).Success dengan Regex.IsMatch(...).
Perbaikan kode yang secara otomatis melakukan transformasi ini tersedia.
Example
Cuplikan kode berikut menunjukkan pelanggaran 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
Cuplikan kode berikut memperbaiki pelanggaran:
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
Kapan harus menekan peringatan
Aman untuk menekan peringatan dari aturan ini jika performa tidak menjadi perhatian.
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 CA1874
// The code that's violating the rule is on this line.
#pragma warning restore CA1874
Untuk menonaktifkan aturan untuk file, folder, atau proyek, atur tingkat keparahannya ke none dalam file konfigurasi.
[*.{cs,vb}]
dotnet_diagnostic.CA1874.severity = none
Untuk informasi selengkapnya, lihat Cara menyembunyikan peringatan analisis kode.