Partage via


CA2264 : Ne passez pas de valeur non nullable à « ArgumentNullException.ThrowIfNull ».

Propriété Value
Identificateur de la règle CA2264
Titre Ne passez pas de valeur non nullable à ' ArgumentNullException.ThrowIfNull'
Catégorie Utilisation
Le correctif est cassant ou non cassant Sans rupture
Activée par défaut dans .NET 9 Comme avertissement

Cause

Lorsqu’une valeur connue pour ne jamais être null est passée à ArgumentNullException.ThrowIfNull(), une exception n’est jamais levée, ce qui rend l’instruction sans opération.

Description de la règle

ArgumentNullException.ThrowIfNull lève lorsque l’argument passé est null. Certaines constructions telles que les structs non nullables (à l’exception de Nullable<T>), les paramètres de type connus comme des structs non nullables, des expressions « nameof() » et des expressions « new » sont connus pour ne jamais être null, de sorte ArgumentNullException.ThrowIfNull qu’ils ne lèveront jamais.

Dans le cas d’un struct, puisque ArgumentNullException.ThrowIfNull accepte un object?, le struct est boxé, ce qui entraîne une pénalité de performances supplémentaire.

Comment corriger les violations

Supprimez l’appel ArgumentNullException.ThrowIfNull .

Exemple

L’extrait de code suivant montre une violation de CA2264 :

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

L’extrait de code suivant corrige la violation :

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

Quand supprimer les avertissements

Il est toujours sûr de supprimer cet avertissement.

Supprimer un avertissement

Si vous voulez supprimer une seule violation, ajoutez des directives de préprocesseur à votre fichier source pour désactiver et réactiver la règle.

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

Pour désactiver la règle sur un fichier, un dossier ou un projet, définissez sa gravité sur none dans le fichier de configuration.

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

Pour plus d’informations, consultez Comment supprimer les avertissements de l’analyse de code.