| 属性 | 值 |
|---|---|
| 规则 ID | CA1860 |
| 标题 | 避免使用“Enumerable.Any()”扩展方法 |
| 类别 | “性能” |
| 修复会引起中断还是不会引起中断 | 非中断 |
| 在 .NET 10 中默认启用 | 作为一种建议 |
| 适用的语言 | C# 和 Visual Basic |
原因
Enumerable.Any 在具有 Length、Count 或 IsEmpty属性 的类型上被调用。
规则说明
要确定集合类型是否具有任何元素,与调用 Enumerable.Any 方法相比,使用 Length、Count 或 IsEmpty 属性(如果可能)更高效、更清晰。
Any() 是一种扩展方法,使用语言集成查询 (LINQ)。 更高效的做法是依赖集合本身的属性,而且它还阐明了意图。
注意
此规则类型于 CA1827:当可以使用 Any() 时,不要使用 Count()/LongCount()。 但是,该规则适用于 Linq Count()方法,而此规则建议使用该Count属性。
如何解决违规
将对 Any() 的调用替换为对集合的 Length、Count 或 IsEmpty 属性的调用。
示例
以下代码片段显示了 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
有关详细信息,请参阅如何禁止显示代码分析警告。