CA1828: No usar CountAsync/LongCountAsync si se puede usar AnyAsync
Propiedad | Value |
---|---|
Identificador de la regla | CA1828 |
Título | No usar CountAsync/LongCountAsync si se puede usar AnyAsync |
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 usó el método CountAsync o LongCountAsync, cuando el método AnyAsync sería más eficaz.
Descripción de la regla
Esta regla marca las llamadas al método LINQ CountAsync y LongCountAsync utilizadas para comprobar si la colección tiene al menos un elemento. Estas llamadas al método requieren enumerar toda la colección para calcular el recuento. La misma comprobación es más rápida con el método AnyAsync, ya que evita enumerar la colección.
Cómo corregir infracciones
Para corregir una infracción, reemplace la llamada al método CountAsync o LongCountAsync por el método AnyAsync. Por ejemplo, en los dos fragmentos de código siguientes se muestra una infracción de la regla y cómo corregirla:
using System.Linq;
using System.Threading.Tasks;
using static Microsoft.EntityFrameworkCore.EntityFrameworkQueryableExtensions;
class C
{
public async Task<string> M1Async(IQueryable<string> list)
=> await list.CountAsync() != 0 ? "Not empty" : "Empty";
public async Task<string> M2Async(IQueryable<string> list)
=> await list.LongCountAsync() > 0 ? "Not empty" : "Empty";
}
using System.Linq;
using System.Threading.Tasks;
using static Microsoft.EntityFrameworkCore.EntityFrameworkQueryableExtensions;
class C
{
public async Task<string> M1Async(IQueryable<string> list)
=> await list.AnyAsync() ? "Not empty" : "Empty";
public async Task<string> M2Async(IQueryable<string> list)
=> await list.AnyAsync() ? "Not empty" : "Empty";
}
Sugerencia
Hay disponible una corrección de código para esta regla en Visual Studio. Para usarlo, coloque el cursor sobre la infracción y presione Ctrl+. (punto). Elija No usar CountAsync() ni LongCountAsync() si se puede usar AnyAsync() en la lista de opciones que se muestra.
Cuándo suprimir las advertencias
Se puede suprimir una infracción de esta regla si no le preocupa el impacto en el rendimiento de la enumeración de recopilaciones innecesaria para calcular el recuento.
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 CA1828
// The code that's violating the rule is on this line.
#pragma warning restore CA1828
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.CA1828.severity = none
Para obtener más información, consulte Procedimiento para suprimir advertencias de análisis de código.
Reglas relacionadas
- CA1826: Usar la propiedad en lugar del método Linq Enumerable
- CA1827: No usar Count/LongCount si se puede usar Any
- CA1829: Usar la propiedad Length/Count en lugar del método Enumerable.Count