CA1028: El almacenamiento de la enumeración debe ser de tipo Int32
Propiedad | Value |
---|---|
Identificador de la regla | CA1028 |
Título | El almacenamiento de la enumeración debe ser de tipo Int32 |
Categoría | Diseño |
La corrección es problemática o no problemática | Problemático |
Habilitado de forma predeterminada en .NET 8 | No |
Causa
El tipo subyacente de una enumeración no es System.Int32.
De forma predeterminada, esta regla solo examina las enumeraciones visibles externamente, pero esto es configurable.
Descripción de la regla
Una enumeración es un tipo de valor que define un conjunto de constantes con nombre relacionadas. De forma predeterminada, el tipo de datos System.Int32 se utiliza para almacenar el valor constante. Aunque puede cambiar este tipo subyacente, no es necesario ni se recomienda en la mayoría de los escenarios. No se consigue un aumento significativo del rendimiento usando un tipo de datos menor que Int32. Si no puede utilizar el tipo de datos predeterminado, debe usar uno de los tipos enteros compatibles con Common Language System (CLS), Byte, Int16, Int32 o Int64 para asegurarse de que todos los valores de la enumeración se puedan representar en lenguajes de programación compatibles con CLS.
Cómo corregir infracciones
Para corregir una infracción de esta regla, a menos que existan problemas de tamaño o compatibilidad, use Int32. En situaciones en las que Int32 no sea lo suficientemente grande como para contener los valores, use Int64. Si la compatibilidad con versiones anteriores requiere un tipo de datos más pequeño, use Byte o Int16.
Cuándo suprimir las advertencias
Suprima una advertencia de esta regla solo si los problemas de compatibilidad con versiones anteriores lo requieren. En las aplicaciones, el no cumplimiento de esta regla normalmente no causa problemas. En el caso de las bibliotecas, en las que se requiere la interoperabilidad de lenguajes, el hecho de no cumplir esta regla podría afectar negativamente a los usuarios.
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 CA1028
// The code that's violating the rule is on this line.
#pragma warning restore CA1028
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.CA1028.severity = none
Para obtener más información, consulte Procedimiento para suprimir advertencias de análisis de código.
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 (Diseño) 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
Ejemplo
En el ejemplo siguiente se muestran dos enumeraciones que no utilizan el tipo de datos subyacente recomendado.
[Flags]
public enum Days : uint
{
None = 0,
Monday = 1,
Tuesday = 2,
Wednesday = 4,
Thursday = 8,
Friday = 16,
All = Monday | Tuesday | Wednesday | Thursday | Friday
}
public enum Color : sbyte
{
None = 0,
Red = 1,
Orange = 3,
Yellow = 4
}
<Flags()>
Public Enum Days As UInteger
None = 0
Monday = 1
Tuesday = 2
Wednesday = 4
Thursday = 8
Friday = 16
All = Monday Or Tuesday Or Wednesday Or Thursday Or Friday
End Enum
Public Enum Color As SByte
None = 0
Red = 1
Orange = 3
Yellow = 4
End Enum
En el ejemplo siguiente se corrige la infracción anterior cambiando el tipo de datos subyacente a Int32.
[Flags]
public enum Days : int
{
None = 0,
Monday = 1,
Tuesday = 2,
Wednesday = 4,
Thursday = 8,
Friday = 16,
All = Monday | Tuesday | Wednesday | Thursday | Friday
}
public enum Color : int
{
None = 0,
Red = 1,
Orange = 3,
Yellow = 4
}
<Flags()>
Public Enum Days As Integer
None = 0
Monday = 1
Tuesday = 2
Wednesday = 4
Thursday = 8
Friday = 16
All = Monday Or Tuesday Or Wednesday Or Thursday Or Friday
End Enum
Public Enum Color As Integer
None = 0
Red = 1
Orange = 3
Yellow = 4
End Enum
Reglas relacionadas
- CA1008: Las enumeraciones deben tener un valor igual a cero
- CA1027: Marcar enumeraciones con FlagsAttribute
- CA2217: No marcar enumeraciones con FlagsAttribute
- CA1700: No nombrar valores de enumeración como 'Reserved'
- CA1712: No utilizar prefijos en valores de enumeración con el nombre del tipo