Preferencia por la comprobación NULL frente a la comprobación de tipo (IDE0150)

Propiedad Value
Identificador de la regla IDE0150
Título Preferencia por la comprobación null frente a la comprobación de tipo
Categoría Estilo
Subcategoría Reglas del lenguaje (preferencias de nivel de expresión)
Lenguajes aplicables C#
Opciones csharp_style_prefer_null_check_over_type_check

Información general

Esta regla de estilo marca el uso de la instrucción is {type} cuando se puede usar is not null en su lugar. Del mismo modo, marca el uso de la instrucción is not {type} en favor de is null. El uso de is null o is not null mejora la legibilidad del código.

Opciones

Las opciones especifican el comportamiento que se quiere que aplique la regla. Para obtener información sobre la configuración de las opciones, consulte Formato de opción.

csharp_style_prefer_null_check_over_type_check

Propiedad Value Descripción
Nombre de la opción csharp_style_prefer_null_check_over_type_check
Valores de opción true Preferir comprobación "null' sobre comprobación de tipo.
false Deshabilita la regla.
Valor de opción predeterminado true

Ejemplo

// Violates IDE0150.
if (numbers is not IEnumerable<int>) ...

// Fixed code.
if (numbers is null) ...

Supresión de una advertencia

Si solo quiere suprimir una única infracción, agregue directivas de preprocesador al archivo de origen para deshabilitar y volver a habilitar la regla.

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

Para deshabilitar la regla de un archivo, una carpeta o un proyecto, establezca su gravedad en none del archivo de configuración.

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

Para deshabilitar todas las reglas de estilo del código, establezca la gravedad de la categoría Style en none del archivo de configuración.

[*.{cs,vb}]
dotnet_analyzer_diagnostic.category-Style.severity = none

Para obtener más información, consulte Procedimiento para suprimir advertencias de análisis de código.

Consulte también