Bagikan melalui


CA1512: Gunakan pembantu lempar argumenOutOfRangeException

Properti Nilai
ID Aturan CA1512
Judul Gunakan pembantu lempar ArgumentOutOfRangeException
Golongan Kemampu
Perbaikan bersifat disruptif atau non-disruptif Tidak Melanggar
Diaktifkan secara default di .NET 8 Sebagai saran

Penyebab

Kode memeriksa apakah argumen kurang dari atau lebih besar dari nilai tertentu dan kemudian secara kondisional melemparkan ArgumentOutOfRangeException.

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 instruksi-cache yang substansial. Metode throw-helper seperti ArgumentOutOfRangeException.ThrowIfGreaterThan lebih sederhana dan lebih efisien daripada if blok yang membangun instans pengecualian baru.

Contoh

Cuplikan kode berikut menunjukkan pelanggaran CA1512:

void M(int arg)
{
    if (arg is 0)
        throw new ArgumentOutOfRangeException(nameof(arg));
    if (arg < 0)
        throw new ArgumentOutOfRangeException(nameof(arg));
    if (arg <= 0)
        throw new ArgumentOutOfRangeException(nameof(arg));
    if (arg <= 42)
        throw new ArgumentOutOfRangeException(nameof(arg));
    if (arg < 42)
        throw new ArgumentOutOfRangeException(nameof(arg));
    if (arg > 42)
        throw new ArgumentOutOfRangeException(nameof(arg));
    if (arg >= 42)
        throw new ArgumentOutOfRangeException(nameof(arg));
    if (arg == 42)
        throw new ArgumentOutOfRangeException(nameof(arg));
    if (arg != 42)
        throw new ArgumentOutOfRangeException(nameof(arg));
}

Cuplikan kode berikut menunjukkan perbaikan:

void M(int arg)
{
    ArgumentOutOfRangeException.ThrowIfZero(arg);
    ArgumentOutOfRangeException.ThrowIfNegative(arg);
    ArgumentOutOfRangeException.ThrowIfNegativeOrZero(arg);
    ArgumentOutOfRangeException.ThrowIfLessThanOrEqual(arg, 42);
    ArgumentOutOfRangeException.ThrowIfLessThan(arg, 42);
    ArgumentOutOfRangeException.ThrowIfGreaterThan(arg, 42);
    ArgumentOutOfRangeException.ThrowIfGreaterThanOrEqual(arg, 42);
    ArgumentOutOfRangeException.ThrowIfEqual(arg, 42);
    ArgumentOutOfRangeException.ThrowIfNotEqual(arg, 42);
}

Cara memperbaiki pelanggaran

if Ganti blok yang melemparkan pengecualian dengan panggilan ke salah satu metode throw-helper berikut:

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 CA1512
// The code that's violating the rule is on this line.
#pragma warning restore CA1512

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

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

Untuk informasi selengkapnya, lihat Cara menyembunyikan peringatan analisis kode.