Compartir vía


Conversión de los campos de estructura en grabables (IDE0064)

Propiedad Value
Identificador de la regla IDE0064
Título Conversión de los campos de estructura en grabables
Categoría CodeQuality
Subcategoría Reglas del lenguaje (preferencias de modificadores)
Lenguajes aplicables C#

Información general

Esta regla detecta estructuras que contienen uno o varios campos readonly y también contiene una asignación a this fuera del constructor. La regla recomienda convertir los campos readonly a campos que no sean de solo lectura, es decir, grabables. Marcar estos campos de estructura como readonly puede provocar un comportamiento inesperado, ya que el valor asignado al campo puede cambiar cuando se asigna this fuera del constructor.

Opciones

Esta regla no tiene opciones de estilo de código asociadas.

Ejemplo

// Code with violations
struct MyStruct
{
    public readonly int Value;

    public MyStruct(int value)
    {
        Value = value;
    }

    public void Test()
    {
        this = new MyStruct(5);
    }
}

// Fixed code
struct MyStruct
{
    public int Value;

    public MyStruct(int value)
    {
        Value = value;
    }

    public void Test()
    {
        this = new MyStruct(5);
    }
}

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

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.IDE0064.severity = none

Para deshabilitar toda esta categoría de reglas, establezca la gravedad de la categoría en none del archivo de configuración.

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

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

Consulte también