通过


CA1860:避免使用“Enumerable.Any()”扩展方法

属性
规则 ID CA1860
标题 避免使用“Enumerable.Any()”扩展方法
类别 “性能”
修复会引起中断还是不会引起中断 非中断
在 .NET 10 中默认启用 作为一种建议
适用的语言 C# 和 Visual Basic

原因

Enumerable.Any 在具有 LengthCountIsEmpty属性 的类型上被调用。

规则说明

要确定集合类型是否具有任何元素,与调用 Enumerable.Any 方法相比,使用 LengthCountIsEmpty 属性(如果可能)更高效、更清晰。

Any() 是一种扩展方法,使用语言集成查询 (LINQ)。 更高效的做法是依赖集合本身的属性,而且它还阐明了意图。

注意

此规则类型于 CA1827:当可以使用 Any() 时,不要使用 Count()/LongCount()。 但是,该规则适用于 Linq Count()方法,而此规则建议使用该Count属性

如何解决违规

将对 Any() 的调用替换为对集合的 LengthCountIsEmpty 属性的调用。

示例

以下代码片段显示了 CA1860 违规:

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

以下代码片段修复了冲突:

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

何时禁止显示警告

如果不考虑性能,则可以安全地禁止显示此警告。

抑制警告

如果只想抑制单个冲突,请将预处理器指令添加到源文件以禁用该规则,然后重新启用该规则。

#pragma warning disable CA1860
// The code that's violating the rule is on this line.
#pragma warning restore CA1860

若要对文件、文件夹或项目禁用该规则,请在none中将其严重性设置为

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

有关详细信息,请参阅如何禁止显示代码分析警告