Compartir vía


CA1860: evite usar el método de extensión "Enumerable.Any()"

Propiedad Value
Identificador de la regla CA1860
Título Evite usar el método de extensión "Enumerable.Any()"
Categoría Rendimiento
La corrección es problemática o no problemática Poco problemático
Habilitado de forma predeterminada en .NET 8 Como sugerencia

Causa

Enumerable.Anyse llama a en un tipo que tiene una Lengthpropiedad , Counto IsEmpty .

Descripción de la regla

Para determinar si un tipo de colección tiene elementos, es más eficiente y claro utilizar Length, Count o IsEmpty (si es posible) que llamar al método Enumerable.Any.

Any(), que es un método de extensión, usa la consulta integrada del lenguaje (LINQ). Es más eficaz confiar en las propiedades propias de la colección y también aclara la intención.

Nota

Esta regla es similar a CA1827: No use Count()/LongCount() cuando se pueda usar Any(). Sin embargo, esa regla se aplica al método LinqCount(), mientras que esta regla sugiere usar la Count propiedad .

Cómo corregir infracciones

Reemplace una llamada a Any() por una llamada a las colecciones Length, Count o la propiedad IsEmpty.

Ejemplo

El siguiente fragmento de código muestra una infracción de la regla CA1860:

bool HasElements(string[] strings)
{
    return strings.Any();
}
Function HasElements(strings As String()) As Boolean
    Return strings.Any()
End Function

El siguiente fragmento de código corrige la infracción:

bool HasElements(string[] strings)
{
    return strings.Length > 0;
}
Function HasElements(strings As String()) As Boolean
    Return strings.Length > 0
End Function

Cuándo suprimir las advertencias

Es seguro suprimir esta advertencia si el rendimiento no es un problema.

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

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.CA1860.severity = none

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