共用方式為


(IDE0200) 移除不必要的 Lambda 運算式

屬性
規則識別碼 IDE0200
標題 移除不必要的 Lambda 運算式
類別 樣式
子類別 語言規則 (程式碼區塊喜好設定)
適用語言 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

如需詳細資訊,請參閱如何隱藏程式碼分析警告

另請參閱