Uproszczenie wyrażenia LINQ (IDE0120)
Właściwość | Wartość |
---|---|
Identyfikator zasady | IDE0120 |
Tytuł | Upraszczanie wyrażenia LINQ |
Kategoria | Styl |
Subcategory (Podkategoria) | Niepotrzebne reguły kodu (preferencje na poziomie wyrażeń) |
Odpowiednie języki | C# i Visual Basic |
Omówienie
Ta reguła flaguje nadmiernie złożone wyrażenia LINQ, w szczególności wyrażenia wywołujące Enumerable.Where<TSource>(IEnumerable<TSource>, Func<TSource,Int32,Boolean>) jedną z następujących metod:
- 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>)
Takie wyrażenia można uprościć, usuwając wywołanie metody Where<TSource>(IEnumerable<TSource>, Func<TSource,Int32,Boolean>) i zamiast tego wywołując przeciążenie Any()
elementu , , Count()
Last()
FirstOrDefault()
LastOrDefault()
First()
, lubSingle
SingleOrDefault()
, które akceptuje funkcję predykatu w celu filtrowania elementów.
Opcje
Ta reguła nie ma skojarzonych opcji stylu kodu.
Przykład
// 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"));
Pomijanie ostrzeżenia
Jeśli chcesz pominąć tylko jedno naruszenie, dodaj dyrektywy preprocesora do pliku źródłowego, aby wyłączyć, a następnie ponownie włączyć regułę.
#pragma warning disable IDE0120
// The code that's violating the rule is on this line.
#pragma warning restore IDE0120
Aby wyłączyć regułę dla pliku, folderu lub projektu, ustaw jego ważność na none
w pliku konfiguracji.
[*.{cs,vb}]
dotnet_diagnostic.IDE0120.severity = none
Aby wyłączyć wszystkie reguły stylu kodu, ustaw ważność kategorii Style
na none
w pliku konfiguracji.
[*.{cs,vb}]
dotnet_analyzer_diagnostic.category-Style.severity = none
Aby uzyskać więcej informacji, zobacz Jak pominąć ostrzeżenia analizy kodu.