Eventos
Cree aplicaciones y agentes de IA
17 mar, 9 p.m. - 21 mar, 10 a.m.
Únete a la serie de encuentros para crear soluciones de IA escalables basadas en casos de uso del mundo real con otros desarrolladores y expertos.
Regístrese ahoraEste explorador ya no es compatible.
Actualice a Microsoft Edge para aprovechar las características, las actualizaciones de seguridad y el soporte técnico más recientes.
Propiedad | Value |
---|---|
Identificador de la regla | CA1027 |
Título | Marcar enumeraciones con FlagsAttribute |
Categoría | Diseño |
La corrección es problemática o no problemática | Poco problemático |
Habilitado de forma predeterminada en .NET 9 | No |
Los valores de una enumeración son potencias de dos, o bien combinaciones de otros valores que se definen en la enumeración, y el atributo System.FlagsAttribute no está presente. Para reducir los falsos positivos, esta regla no notifica una infracción en las enumeraciones que tienen valores contiguos.
De forma predeterminada, esta regla solo examina las enumeraciones visibles externamente, pero esto es configurable.
Una enumeración es un tipo de valor que define un conjunto de constantes con nombre relacionadas. Aplique FlagsAttribute a una enumeración cuando se pueda combinar con sentido sus constantes con nombre. Por ejemplo, considere una enumeración de los días de la semana en una aplicación que realiza un seguimiento de los recursos del día que están disponibles. Si la disponibilidad de cada recurso se codifica mediante la enumeración que tiene FlagsAttribute presente, se puede representar cualquier combinación de días. Sin el atributo, solo se puede representar un día de la semana.
En el caso de los campos que almacenan enumeraciones combinables, los valores de enumeración individuales se tratan como grupos de bits en el campo. Por este motivo, estos campos a veces se denominan campos de bits. Si quiere combinar los valores de enumeración para el almacenamiento en un campo de bits, utilice los operadores condicionales booleanos. Para probar un campo de bits a fin de determinar si un valor de enumeración específico está presente, utilice los operadores lógicos booleanos. Para que un campo de bits almacene y recupere correctamente los valores de enumeración combinados, cada valor que se define en la enumeración debe ser una potencia de dos. De lo contrario, los operadores lógicos booleanos no podrán extraer los valores de enumeración individuales almacenados en el campo.
Para corregir una infracción de esta regla, agregue FlagsAttribute a la enumeración.
Suprima una advertencia de esta regla si no quiere que los valores de enumeración sean combinables.
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 CA1027
// The code that's violating the rule is on this line.
#pragma warning restore CA1027
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.CA1027.severity = none
Para obtener más información, consulte Procedimiento para suprimir advertencias de análisis de código.
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 (Diseño) a las que se aplica. Para más información, vea Opciones de configuración de reglas de calidad de código.
Puede configurar en qué partes del código base se ejecutará esta regla, en función de su accesibilidad, mediante la configuración de la opción api_surface. 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
Nota
Reemplace la parte XXXX
de CAXXXX
por el identificador de la regla que sea de aplicación.
En el ejemplo siguiente, DaysEnumNeedsFlags
es una enumeración que cumple los requisitos para usar FlagsAttribute, pero no lo tiene. La enumeración ColorEnumShouldNotHaveFlag
no tiene valores que sean potencias de dos, pero especifica FlagsAttribute incorrectamente. Esto infringe la regla CA2217: No marcar enumeraciones con FlagsAttribute.
// Violates rule: MarkEnumsWithFlags.
public enum DaysEnumNeedsFlags
{
None = 0,
Monday = 1,
Tuesday = 2,
Wednesday = 4,
Thursday = 8,
Friday = 16,
All = Monday | Tuesday | Wednesday | Thursday | Friday
}
// Violates rule: DoNotMarkEnumsWithFlags.
[FlagsAttribute]
public enum ColorEnumShouldNotHaveFlag
{
None = 0,
Red = 1,
Orange = 3,
Yellow = 4
}
Comentarios de .NET
.NET es un proyecto de código abierto. Selecciona un vínculo para proporcionar comentarios:
Eventos
Cree aplicaciones y agentes de IA
17 mar, 9 p.m. - 21 mar, 10 a.m.
Únete a la serie de encuentros para crear soluciones de IA escalables basadas en casos de uso del mundo real con otros desarrolladores y expertos.
Regístrese ahora