删除不必要的 Lambda 表达式 (IDE0200)
属性 | 值 |
---|---|
规则 ID | IDE0200 |
标题 | 删除不必要的 Lambda 表达式 |
类别 | Style |
Subcategory | 语言规则(代码块首选项) |
适用的语言 | C# 11+ |
选项 | csharp_style_prefer_method_group_conversion |
概述
此规则会标记 Lambda 表达式的不必要的使用。 如果以下所有条件都成立,则可能不需要 Lambda 表达式:
- 表达式包括方法调用。
- Lambda 表达式的参数数量和顺序与方法调用相同。
- 方法调用没有副作用。
- Lambda 表达式未分配给非委托类型。
- 如果调用是泛型方法,则提供类型参数。
- 调用方法的返回类型可以转换为 Lambda 表达式的返回类型。
- 方法组中只有一个适用的方法。
选项
选项指定你希望规则强制实施的行为。 若要了解如何配置选项,请参阅选项格式。
csharp_style_prefer_method_group_conversion
属性 | 值 | 说明 |
---|---|---|
选项名称 | csharp_style_prefer_method_group_conversion | |
选项值 | true |
首选将 Lambda 表达式转换为方法组。 |
false |
禁用规则。 | |
默认选项值 | true |
示例
// Code with violations.
bool IsEven(int x) => x % 2 == 0;
_ = new[] { 1, 2, 3 }.Where(n => IsEven(n));
// Fixed code.
bool IsEven(int x) => x % 2 == 0;
_ = new[] { 1, 2, 3 }.Where(IsEven);
抑制警告
如果只想抑制单个冲突,请将预处理器指令添加到源文件以禁用该规则,然后重新启用该规则。
#pragma warning disable IDE0200
// The code that's violating the rule is on this line.
#pragma warning restore IDE0200
若要对文件、文件夹或项目禁用该规则,请在配置文件中将其严重性设置为 none
。
[*.{cs,vb}]
dotnet_diagnostic.IDE0200.severity = none
若要禁用所有代码样式规则,请在配置文件中将类别 Style
的严重性设置为 none
。
[*.{cs,vb}]
dotnet_analyzer_diagnostic.category-Style.severity = none
有关详细信息,请参阅如何禁止显示代码分析警告。