Udostępnij za pośrednictwem


Uproszczenie wyrażenia LINQ (IDE0120)

Własność Wartość
identyfikator reguły IDE0120
Tytuł Upraszczanie wyrażenia LINQ
Kategoria Styl
Podkategoria Niepotrzebne reguły kodu (preferencje na poziomie wyrażenia)
języki stosowane C# i Visual Basic

Przegląd

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>), a następnie jedną z następujących metod:

Takie wyrażenia można uprościć, usuwając wywołanie Where<TSource>(IEnumerable<TSource>, Func<TSource,Int32,Boolean>) i zamiast tego wywołując przeciążenie Any(), Count(), First(), FirstOrDefault(), Last(), LastOrDefault(), Singlelub SingleOrDefault(), które akceptuje funkcję predykatywną 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.

Zobacz też