Nota
L'accés a aquesta pàgina requereix autorització. Podeu provar d'iniciar la sessió o de canviar els directoris.
L'accés a aquesta pàgina requereix autorització. Podeu provar de canviar els directoris.
| Propiedad | Valor |
|---|---|
| Identificador de la regla | CA2011 |
| Título | No asigne la propiedad dentro de su setter |
| Categoría | Confiabilidad |
| La corrección interrumpe o no interrumpe | Sin interrupción |
| Habilitado de forma predeterminada en .NET 10 | Como sugerencia |
| Idiomas aplicables | C# y Visual Basic |
Causa
Se ha asignado por error un valor a una propiedad dentro de su propio accesor set.
Descripción de la regla
Asignar una propiedad a sí misma en su descriptor de acceso set produce una cadena infinita de llamadas recursivas al descriptor de acceso set, Esto da como resultado un StackOverflowException en tiempo de ejecución. Este error es habitual cuando la propiedad y el campo de respaldo para almacenar el valor de propiedad tienen nombres parecidos. En lugar de asignar el valor al campo de respaldo, se asignó accidentalmente a la propiedad.
Cómo corregir infracciones
Para corregir infracciones, reemplace la asignación que produce la infracción a la propiedad por una asignación al campo de respaldo o cambie a usar una propiedad automática. Por ejemplo, el siguiente fragmento de código muestra una infracción de la regla y dos maneras de corregirla:
public class C
{
// Backing field for property 'P'
private int p;
public int P
{
get
{
return p;
}
set
{
// CA2011: Accidentally assigned to property, instead of the backing field.
P = value;
}
}
}
public class C
{
// Backing field for property 'P'
private int _p;
public int P
{
get
{
return _p;
}
set
{
// Option 1: Assign to backing field and rename the backing field for clarity.
_p = value;
}
}
}
public class C
{
// Option 2: Use auto-property.
public int P { get; set; }
}
Cuándo suprimir las advertencias
Está bien suprimir las infracciones de esta regla si está seguro de que las llamadas recursivas al accesor set están protegidas de forma condicional para evitar una recursividad infinita.
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 CA2011
// The code that's violating the rule is on this line.
#pragma warning restore CA2011
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.CA2011.severity = none
Para obtener más información, consulte Procedimiento para suprimir advertencias de análisis de código.