Uso del cuerpo de expresiones para los operadores (IDE0023 e IDE0024)

En este artículo se describen dos reglas relacionadas, IDE0023 y IDE0024, que se aplican a operadores de conversión y a operadores a secas, respectivamente.

Propiedad Value
Identificador de la regla IDE0023
Título Uso del cuerpo de expresiones para los operadores de conversión
Categoría Estilo
Subcategoría Reglas del lenguaje (miembros con forma de expresión)
Lenguajes aplicables C#
Opciones csharp_style_expression_bodied_operators
Propiedad Value
Identificador de la regla IDE0024
Título Uso del cuerpo de expresiones para los operadores
Categoría Estilo
Subcategoría Reglas del lenguaje (miembros con forma de expresión)
Lenguajes aplicables C#
Opciones csharp_style_expression_bodied_operators

Información general

Esta regla de estilo se refiere al uso de cuerpos de expresiones frente a cuerpos de bloque para los operadores.

Opciones

Establezca el valor de la opción asociada a estas reglas para especificar si se prefieren cuerpos de expresiones o cuerpos de bloques para los operadores y, si se elije la primera opción, para saber si solo se prefieren para expresiones de una sola línea.

Para más información sobre la configuración de las opciones, consulte Formato de las opciones.

csharp_style_expression_bodied_operators

Propiedad Value Descripción
Nombre de la opción csharp_style_expression_bodied_operators
Valores de opción true Se prefieren cuerpos de expresiones para los operadores
when_on_single_line Se prefieren cuerpos de expresiones para los operadores si las expresiones son solo de una línea
false Se prefieren cuerpos de bloques para los operadores
Valor de opción predeterminado 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); }

Supresión de una advertencia

Si solo quiere suprimir una única infracción, agregue directivas de preprocesador al archivo de origen para deshabilitar y volver a habilitar la regla.

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

Para deshabilitar la regla de un archivo, una carpeta o un proyecto, establezca su gravedad en none del archivo de configuración.

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

Para deshabilitar todas las reglas de estilo del código, establezca la gravedad de la categoría Style en none del archivo de configuración.

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

Para obtener más información, consulte Procedimiento para suprimir advertencias de análisis de código.

Consulte también