Поделиться через


Упрощение выражения LINQ (IDE0120)

Свойство Ценность
идентификатор правила IDE0120
Заголовок Упрощение выражения LINQ
Категория Стиль
подкатегории Ненужные правила кода (предпочтения уровня выражения)
применимые языки C# и Visual Basic

Обзор

Это правило помечает слишком сложные выражения LINQ, в частности выражения, которые вызывают Enumerable.Where<TSource>(IEnumerable<TSource>, Func<TSource,Int32,Boolean>), следом за чем идет вызов одного из следующих методов:

Такие выражения можно упростить, удалив вызов 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

Дополнительные сведения см. в статье Подавление предупреждений анализа кода.

См. также