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


Использование текста выражения для операторов (IDE0023 и IDE0024)

В этой статье описаны два связанных правила, IDE0023 и IDE0024, которые применяются, соответственно, к операторам преобразования и к операторам .

Свойство Ценность
идентификатор правила IDE0023
Заголовок Использовать тело выражения для операторов преобразования
Категория Стиль
подкатегория Языковые правила (элементы с выражением)
применимые языки C#
Параметры csharp_style_expression_bodied_operators
Свойство Ценность
идентификатор правила IDE0024
Название Использование текста выражения для операторов
категория Стиль
Подкатегория Языковые правила (элементы с выражением)
применимые языки C#
Опции csharp_style_expression_bodied_operators

Обзор

Это правило стиля касается использования тел выражений и блоков для операторов.

Параметры

Установите значение связанной опции для этих правил, чтобы указать, предпочтительны ли тела выражений или блоки для операторов, и если предпочтительны тела выражений, предпочтительны ли они только для однострочных выражений.

Дополнительные сведения о настройке опций см. в формате опции.

Стиль C# для операторов с использованием лямбда-выражений

Свойство Ценность Описание
имя параметра csharp_style_expression_bodied_operators
значения опций true Предпочитать тела выражений для операторов
when_on_single_line Предпочитать тела выражений для операторов, когда они будут одной строкой
false Используйте блочные тела для операторов
значение параметра по умолчанию false
// csharp_style_expression_bodied_operators = true
public static ComplexNumber operator + (ComplexNumber c1, ComplexNumber c2)
    => new ComplexNumber(c1.Real + c2.Real, c1.Imaginary + c2.Imaginary);

// csharp_style_expression_bodied_operators = false
public static ComplexNumber operator + (ComplexNumber c1, ComplexNumber c2)
{ return new ComplexNumber(c1.Real + c2.Real, c1.Imaginary + c2.Imaginary); }

Подавление предупреждения

Если вы хотите отключить только одно нарушение, добавьте директивы препроцессора в исходный файл, чтобы отключить и повторно включить правило.

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

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

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

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

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

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

См. также