CA1805: No inicializar innecesariamente
Propiedad | Value |
---|---|
Identificador de la regla | CA1805 |
Título | No inicializar innecesariamente |
Categoría | Rendimiento |
La corrección es problemática o no problemática | Poco problemático |
Habilitado de forma predeterminada en .NET 9 | No |
Causa
Un campo de una clase se inicializa explícitamente al valor predeterminado del tipo de ese campo.
Descripción de la regla
El entorno de ejecución de .NET inicializa todos los campos de tipos de referencia a sus valores predeterminados antes de ejecutar el constructor. En la mayoría de los casos, inicializar explícitamente un campo a su valor predeterminado en un constructor es redundante, agrega costos de mantenimiento y posiblemente degrada el rendimiento (por ejemplo, con un mayor tamaño de ensamblado), por lo que se puede quitar la inicialización explícita.
Cómo corregir infracciones
En la mayoría de los casos, la corrección adecuada consiste en eliminar la inicialización innecesaria.
class C
{
// Violation
int _value1 = 0;
// Fixed
int _value1;
}
En algunos casos, eliminar la inicialización puede dar lugar a la emisión de advertencias CS0649 posteriores, debido a que el campo conserva su valor predeterminado de forma indefinida. En tales casos, puede ser mejor eliminar el campo por completo o reemplazarlo por una propiedad:
class C
{
// Violation
private static readonly int s_value = 0;
// Fixed
private static int Value => 0;
}
Cuándo suprimir las advertencias
Esta advertencia siempre se puede suprimir, ya que simplemente resalta código potencialmente innecesario y el trabajo que se puede evitar.
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 CA1805
// The code that's violating the rule is on this line.
#pragma warning restore CA1805
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.CA1805.severity = none
Para obtener más información, consulte Procedimiento para suprimir advertencias de análisis de código.