Compartir a través de


Usar la expresión de colección para Create() (IDE0303)

Propiedad Importancia
ID de regla IDE0303
Título Usar la expresión de colección para Crear
Categoría Estilo
Subcategoría Reglas del lenguaje (preferencias de nivel de expresión)
Idiomas aplicables C# 12+
Opciones dotnet_style_prefer_collection_expression

Información general

Esta regla marca dónde se usa un Create() método o un método similar designado como método de construcción de colección (mediante el CollectionBuilderAttribute atributo) para inicializar una colección y ofrece reemplazarla por una expresión de colección ([...]).

Los métodos Create() son comunes para las colecciones inmutables, por ejemplo, ImmutableArray.Create(1, 2, 3).

Nota:

Esta regla requiere versiones más recientes de las API inmutables (por ejemplo, System.Collections.Immutable), que optan por el patrón collection-expression.

Opciones

Las opciones especifican el comportamiento que se quiere que aplique la regla. Para obtener información sobre cómo configurar opciones, vea Formato de opción.

dotnet_style_prefer_collection_expression

Propiedad Importancia Descripción
Nombre de opción dotnet_style_prefer_collection_expression
Valores de opción true | when_types_exactly_match Prefiere usar expresiones de colección solo cuando los tipos coinciden exactamente, por ejemplo, List<int> list = new List<int>() { 1, 2 };.
when_types_loosely_match* Prefiere usar expresiones de colección incluso cuando los tipos coinciden de forma flexible, por ejemplo, IEnumerable<int> list = new List<int>() { 1, 2 };. El tipo de destino debe coincidir con el tipo en el lado derecho o ser uno de los siguientes tipos: IEnumerable<T>, ICollection<T>, IList<T>, IReadOnlyCollection<T>, IReadOnlyList<T>.
false | never Deshabilita la regla.
Valor de opción predeterminado when_types_loosely_match*

*Cuando se usa esta opción, la corrección de código podría cambiar la semántica del código.

Ejemplo

// Code with violations.
ImmutableArray<int> i = ImmutableArray.Create(1, 2, 3);
IEnumerable<int> j = ImmutableArray.Create(1, 2, 3);

// Fixed code.
ImmutableArray<int> i = [1, 2, 3];
IEnumerable<int> j = [1, 2, 3];

En el fragmento de código siguiente se muestra un ejemplo con un tipo personalizado anotado con CollectionBuilderAttribute.

public class Program
{
    public static void Main()
    {
        // IDE0303 violation.
        MyCollection<int> c = MyCollection.Create(1, 2, 3);

        // IDE0303 fixed code.
        MyCollection<int> c = [1, 2, 3];
    }
}

static partial class MyCollection
{
    public static MyCollection<T> Create<T>(System.ReadOnlySpan<T> values) => default;
    public static MyCollection<T> Create<T>(T t1, T t2, T t3) => default;
}

[CollectionBuilder(typeof(MyCollection), "Create")]
class MyCollection<T> : IEnumerable<T>
{
    public IEnumerator<T> GetEnumerator() => default;
    IEnumerator IEnumerable.GetEnumerator() => default;
}

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 IDE0303
// The code that's violating the rule is on this line.
#pragma warning restore IDE0303

Para deshabilitar la regla de un archivo, una carpeta o un proyecto, establezca su gravedad none en el archivo de configuración.

[*.{cs,vb}]
dotnet_diagnostic.IDE0303.severity = none

Para deshabilitar todas las reglas de estilo de código, cambie la gravedad de la categoría Style a none en el archivo de configuración .

[*.{cs,vb}]
dotnet_analyzer_diagnostic.category-Style.severity = none

Para obtener más información, consulte Cómo suprimir advertencias de análisis de código.

Consulte también