Zjednodušení výrazu LINQ (IDE0120)

Vlastnost Hodnota
ID pravidla IDE0120
Název Zjednodušení výrazu LINQ
Kategorie Styl
Subcategory Nepotřebná pravidla kódu (předvolby na úrovni výrazu)
Příslušné jazyky C# a Visual Basic

Přehled

Toto pravidlo označuje příliš složité výrazy LINQ, konkrétně výrazy, které volají Enumerable.Where<TSource>(IEnumerable<TSource>, Func<TSource,Int32,Boolean>) a za kterými následuje jedna z následujících metod:

Tyto výrazy lze zjednodušit tak, že odeberete volání Where<TSource>(IEnumerable<TSource>, Func<TSource,Int32,Boolean>) a místo toho zavoláte přetížení Any(), Count()First(), , FirstOrDefault(), Last(), LastOrDefault(), Singlenebo SingleOrDefault() , která přijímá predikátovou funkci pro filtrování prvků.

Možnosti

Toto pravidlo nemá žádné přidružené možnosti stylu kódu.

Příklad

// 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"));

Potlačení upozornění

Pokud chcete potlačit pouze jedno porušení, přidejte do zdrojového souboru direktivy preprocesoru, aby se pravidlo zakázalo a znovu povolte.

#pragma warning disable IDE0120
// The code that's violating the rule is on this line.
#pragma warning restore IDE0120

Pokud chcete pravidlo pro soubor, složku nebo projekt zakázat, nastavte jeho závažnost none na v konfiguračním souboru.

[*.{cs,vb}]
dotnet_diagnostic.IDE0120.severity = none

Pokud chcete zakázat všechna pravidla stylu kódu, nastavte v konfiguračním souboru závažnost kategorie Style na none .

[*.{cs,vb}]
dotnet_analyzer_diagnostic.category-Style.severity = none

Další informace najdete v tématu Jak potlačit upozornění analýzy kódu.

Viz také