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

属性
规则 ID CA1860
标题 避免使用“Enumerable.Any()”扩展方法
类别 “性能”
修复是中断修复还是非中断修复 非中断
在 .NET 9 中默认启用 作为建议

原因

Enumerable.Any在具有 、或IsEmpty属性的类型上调用 < a0LengthCount/>。

规则说明

相比调用 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

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