Usar la expresión de colección para stackalloc (IDE0302)
Propiedad | Value |
---|---|
Identificador de la regla | IDE0302 |
Título | Uso de la expresión de colección para stackalloc |
Categoría | Estilo |
Subcategoría | Reglas del lenguaje (preferencias de nivel de expresión) |
Lenguajes aplicables | C# 12+ |
Opciones | dotnet_style_prefer_collection_expression |
Información general
Esta regla es similar a Usar expresión de colección para la matriz (IDE0300), salvo que busca stackalloc
en lugar de matrices. Al igual que IDE0300, ofrece convertir el código para usar una expresión de colección. Por ejemplo, stackalloc int[] { ... }
y stackalloc [] { ... }
se simplifican en [...]
.
Nota:
Esta regla solo está disponible en .NET 8 y versiones posteriores, donde los valores se pueden conservar en la pila.
Opciones
Las opciones especifican el comportamiento que se quiere que aplique la regla. Para más información sobre cómo configurar opciones, consulte Formato de opción.
dotnet_style_prefer_collection_expression
Propiedad | Valor | Descripción |
---|---|---|
Nombre de la opción | dotnet_style_prefer_collection_expression | |
Valores de opción | true | when_types_exactly_match |
Preferencia de uso de expresiones de colección. |
false | never |
Deshabilita la regla. | |
Valor de opción predeterminado | true |
Ejemplo
// Code with violations.
ReadOnlySpan<int> x = stackalloc int[] { 1, 2, 3 };
// Fixed code.
ReadOnlySpan<int> x = [1, 2, 3];
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 IDE0302
// The code that's violating the rule is on this line.
#pragma warning restore IDE0302
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.IDE0302.severity = none
Para deshabilitar todas las reglas de estilo del código, establezca la gravedad de la categoría Style
en none
del archivo de configuración.
[*.{cs,vb}]
dotnet_analyzer_diagnostic.category-Style.severity = none
Para obtener más información, consulte Procedimiento para suprimir advertencias de análisis de código.