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