簡化 LINQ 運算式 (IDE0120)
財產 | 價值 |
---|---|
規則標識碼 | IDE0120 |
標題 | 簡化 LINQ 運算式 |
類別 | 風格 |
子類別 | 不必要的程式代碼規則 (運算式層級喜好設定) |
適用的語言 | 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
如需詳細資訊,請參閱 如何在隱藏程式代碼分析警告。