CA2226: Los operadores deben tener sobrecargas simétricas

Propiedad Value
Identificador de la regla CA2226
Título Los operadores deben tener sobrecargas simétricas
Categoría Uso
La corrección es problemática o no problemática Poco problemático
Habilitado de forma predeterminada en .NET 8 No

Causa

Un tipo implementa el operador de igualdad o de desigualdad y no implementa el operador opuesto.

De forma predeterminada, esta regla solo examina los tipos visibles externamente, pero es configurable.

Descripción de la regla

No hay ninguna circunstancia en la que la igualdad o desigualdad sea aplicable a las instancias de un tipo, y el operador opuesto es indefinido. Normalmente, los tipos implementan el operador de desigualdad devolviendo el valor negado del operador de igualdad.

El compilador de C# emite un error para las infracciones de esta regla.

Cómo corregir infracciones

Para corregir una infracción de esta regla, implemente los operadores de igualdad y desigualdad, o bien quite el que esté presente.

Cuándo suprimir las advertencias

No suprima las advertencias de esta regla. Si lo hace, el tipo no funcionará de forma coherente con .NET.

Configuración del código para analizar

Use la opción siguiente para configurar en qué partes del código base ejecutar esta regla.

Puede configurar esta opción solo para esta regla, para todas las reglas a las que se aplica o para todas las reglas de esta categoría (Uso) a las que se aplica. Para más información, vea Opciones de configuración de reglas de calidad de código.

Incluir superficies de API específicas

Puede configurar en qué partes del código base ejecutar esta regla, en función de su accesibilidad. Por ejemplo, para especificar que la regla solo se debe ejecutar en la superficie de API no públicas, agregue el siguiente par clave-valor a un archivo .editorconfig en el proyecto:

dotnet_code_quality.CAXXXX.api_surface = private, internal