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 | CA2264 |
| Judul | Jangan meneruskan nilai yang tidak bisa bernilai null ke ArgumentNullException.ThrowIfNull |
| Kategori | Penggunaan |
| Perbaikan bersifat merusak atau tidak merusak | Tidak terputus |
| Diaktifkan secara default di .NET 10 | Sebagai peringatan |
| Bahasa yang berlaku | C# dan Visual Basic |
Penyebab
Nilai yang dikenal tidak pernah null diteruskan ke ArgumentNullException.ThrowIfNull().
Deskripsi aturan
ArgumentNullException.ThrowIfNull melempar ketika argumen yang diteruskan adalah null. Konstruksi tertentu seperti struct yang tidak dapat bernilai null (kecuali untuk Nullable<T>), parameter tipe yang diketahui sebagai struct yang tidak dapat bernilai null, ekspresi 'nameof()', dan ekspresi 'new' dikenal tidak pernah null, sehingga ArgumentNullException.ThrowIfNull tidak akan pernah melempar. Dengan demikian, panggilan ArgumentNullException.ThrowIfNull tidak perlu.
Dalam kasus struct, karena ArgumentNullException.ThrowIfNull menerima object?, struktur dikotak, yang menyebabkan penalti performa tambahan.
Cara memperbaiki pelanggaran
ArgumentNullException.ThrowIfNull Hapus panggilan.
Contoh
Cuplikan kode berikut menunjukkan pelanggaran CA2264:
static void Print(int value)
{
ArgumentNullException.ThrowIfNull(value);
Console.WriteLine(value);
}
Cuplikan kode berikut memperbaiki pelanggaran:
static void Print(int value)
{
Console.WriteLine(value.Value);
}
Kapan harus menekan peringatan
Selalu aman untuk menekan peringatan ini.
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 CA2264
// The code that's violating the rule is on this line.
#pragma warning restore CA2264
Untuk menonaktifkan aturan untuk file, folder, atau proyek, atur tingkat keparahannya ke none dalam file konfigurasi.
[*.{cs,vb}]
dotnet_diagnostic.CA2264.severity = none
Untuk informasi selengkapnya, lihat Cara menyembunyikan peringatan analisis kode.