Упрощение выражения 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

Чтобы отключить все правила в стиле кода, задайте серьезность для категории Stylenone в файле конфигурации.

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

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

См. также