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.
| Properti | Nilai |
|---|---|
| ID Aturan | CA1510 |
| Judul | Gunakan fungsi pembantu lempar ArgumentNullException |
| Kategori | Kemampu |
| Perbaikan bersifat merusak atau tidak merusak | Tidak Melanggar |
| Diaktifkan secara default di .NET 10 | Sebagai saran |
| Bahasa yang berlaku | C# dan Visual Basic |
Penyebab
Kode memeriksa apakah argumen adalah null dan kemudian melemparkan ArgumentNullException jika syarat tertentu terpenuhi.
Deskripsi aturan
Pemeriksaan argumen memiliki dampak besar pada ukuran kode dan sering mendominasi kode untuk fungsi kecil dan setter properti. Pemeriksaan ini mencegah inlining dan menyebabkan polusi cache instruksi yang substansial. Metode throw-helper seperti ArgumentNullException.ThrowIfNull lebih mudah dan lebih efisien daripada blok if untuk membangun instans pengecualian baru.
Contoh
Cuplikan kode berikut menunjukkan pelanggaran CA1510:
void M(string arg)
{
if (arg is null)
throw new ArgumentNullException(nameof(arg));
}
Cuplikan kode berikut menunjukkan perbaikan:
void M(string arg)
{
ArgumentNullException.ThrowIfNull(arg);
}
Cara memperbaiki pelanggaran
Ganti blok if yang melempar pengecualian dengan panggilan ke ArgumentNullException.ThrowIfNull. Atau, di Visual Studio, gunakan menu bola lampu untuk memperbaiki kode Anda secara otomatis.
Kapan harus menekan peringatan
Aman untuk menyembunyikan pelanggaran aturan ini jika Anda tidak khawatir tentang pemeliharaan kode Anda. Tidak masalah juga untuk menekan pelanggaran yang diidentifikasi sebagai positif palsu.
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 CA1510
// The code that's violating the rule is on this line.
#pragma warning restore CA1510
Untuk menonaktifkan aturan untuk file, folder, atau proyek, atur tingkat keparahannya ke none dalam file konfigurasi.
[*.{cs,vb}]
dotnet_diagnostic.CA1510.severity = none
Untuk informasi selengkapnya, lihat Cara menyembunyikan peringatan analisis kode.