Dela via


CA2264: Skicka inte ett icke-nullbart värde till "ArgumentNullException.ThrowIfNull"

Property Värde
Regel-ID CA2264
Title Skicka inte ett icke-nullbart värde till ArgumentNullException.ThrowIfNull
Kategori Användning
Korrigeringen är icke-bakåtkompatibel Icke-icke-bryta
Aktiverad som standard i .NET 9 Som varning

Orsak

När ett värde som är känt för att aldrig vara null skickas till ArgumentNullException.ThrowIfNull()genereras aldrig ett undantag, vilket gör -instruktionen till en no-op.

Regelbeskrivning

ArgumentNullException.ThrowIfNull genererar när det skickade argumentet är null. Vissa konstruktioner som icke-nullable structs (förutom ), typparametrar som är kända för Nullable<T>att vara icke-nullable structs, "nameof()" uttryck och "nya" uttryck är kända för att aldrig vara null, så ArgumentNullException.ThrowIfNull kommer aldrig att kasta.

När det gäller en struct, eftersom ArgumentNullException.ThrowIfNull accepterar en object?, boxas structen, vilket orsakar ytterligare en prestandastraff.

Så här åtgärdar du överträdelser

Ta bort anropet ArgumentNullException.ThrowIfNull .

Exempel

Följande kodfragment visar ett brott mot CA2264:

static void Print(int value)
{
    ArgumentNullException.ThrowIfNull(value);
    Console.WriteLine(value);
}

Följande kodfragment åtgärdar överträdelsen:

static void Print(int value)
{
    Console.WriteLine(value.Value);
}

När du ska ignorera varningar

Det är alltid säkert att undertrycka den här varningen.

Ignorera en varning

Om du bara vill förhindra en enda överträdelse lägger du till förprocessordirektiv i källfilen för att inaktivera och aktiverar sedan regeln igen.

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

Om du vill inaktivera regeln för en fil, mapp eller ett projekt anger du dess allvarlighetsgrad till none i konfigurationsfilen.

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

Mer information finns i Så här utelämnar du kodanalysvarningar.