简化 LINQ 表达式 (IDE0120)
属性 | 值 |
---|---|
规则 ID | IDE0120 |
标题 | 简化 LINQ 表达式 |
类别 | Style |
Subcategory | 不必要的代码规则(表达式级首选项) |
适用的语言 | C# 和 Visual Basic |
概述
此规则可标记过于复杂的 LINQ 表达式,特别是调用 Enumerable.Where<TSource>(IEnumerable<TSource>, Func<TSource,Int32,Boolean>) 后跟以下方法之一的表达式:
- Any<TSource>(IEnumerable<TSource>)
- Count<TSource>(IEnumerable<TSource>)
- First<TSource>(IEnumerable<TSource>)
- FirstOrDefault<TSource>(IEnumerable<TSource>)
- Last<TSource>(IEnumerable<TSource>)
- LastOrDefault<TSource>(IEnumerable<TSource>)
- Single<TSource>(IEnumerable<TSource>)
- SingleOrDefault<TSource>(IEnumerable<TSource>)
此类表达式可以通过以下方式简化:删除对 Where<TSource>(IEnumerable<TSource>, Func<TSource,Int32,Boolean>) 的调用,改为调用 Any()
、Count()
、First()
、FirstOrDefault()
、Last()
、LastOrDefault()
、Single
或 SingleOrDefault()
的重载,该重载接受谓词函数来筛选元素。
选项
此规则没有关联的代码样式选项。
示例
// Code with violations.
IEnumerable<string> words = new List<string> { "hello", "world", "!" };
var result = words.Where(x => x.Equals("hello")).Any();
// Fixed code.
IEnumerable<string> words = new List<string> { "hello", "world", "!" };
var result = words.Any(x => x.Equals("hello"));
抑制警告
如果只想抑制单个冲突,请将预处理器指令添加到源文件以禁用该规则,然后重新启用该规则。
#pragma warning disable IDE0120
// The code that's violating the rule is on this line.
#pragma warning restore IDE0120
若要对文件、文件夹或项目禁用该规则,请在配置文件中将其严重性设置为 none
。
[*.{cs,vb}]
dotnet_diagnostic.IDE0120.severity = none
若要禁用所有代码样式规则,请在配置文件中将类别 Style
的严重性设置为 none
。
[*.{cs,vb}]
dotnet_analyzer_diagnostic.category-Style.severity = none
有关详细信息,请参阅如何禁止显示代码分析警告。