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
Se llama a Enumerable.Any en un tipo que tiene una propiedad Length
, Count
o propiedadIsEmpty
.
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 sugiere usar el métodoCount()
Linq, mientras que esta regla sugiere usar la propiedadCount
.
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.
Reglas relacionadas
Comentarios
https://aka.ms/ContentUserFeedback.
Próximamente: A lo largo de 2024 iremos eliminando gradualmente GitHub Issues como mecanismo de comentarios sobre el contenido y lo sustituiremos por un nuevo sistema de comentarios. Para más información, vea:Enviar y ver comentarios de