Compartir a través de


Eliminación de expresiones lambda innecesarias (IDE0200)

Propiedad Valor
Identificador de la regla IDE0200
Título Eliminación de expresiones lambda innecesarias
Categoría Estilo
Subcategoría Reglas de lenguaje (preferencias de bloque de código)
idiomas aplicables C# 11+
Opciones csharp_style_prefer_method_group_conversion

Visión general

Esta regla marca el uso de una expresión lambda donde no es necesario. Las expresiones lambda pueden ser innecesarias cuando se cumplen todas las siguientes condiciones:

  • La expresión incluye una invocación de método.
  • La expresión lambda tiene el mismo número y orden de parámetros que la invocación del método.
  • La invocación del método no tiene efectos secundarios.
  • La expresión lambda no está asignada a un tipo no delegado.
  • Si la invocación es un método genérico, se proporcionan los argumentos de tipo.
  • El tipo de valor devuelto del método invocado se puede convertir al tipo de valor devuelto de la expresión lambda.
  • Solo hay un método aplicable en el grupo de métodos.

Opciones

Las opciones especifican el comportamiento que desea que aplique la regla. Para obtener información sobre cómo configurar opciones, vea Formato de opción.

csharp_style_prefer_method_group_conversion

Propiedad Valor Descripción
nombre de opción csharp_style_prefer_method_group_conversion
Valores de opción true Prefiere convertir una expresión lambda en un grupo de métodos.
false Deshabilita la regla.
valor de opción predeterminado true

Ejemplo

// Code with violations.
bool IsEven(int x) => x % 2 == 0;
_ = new[] { 1, 2, 3 }.Where(n => IsEven(n));

// Fixed code.
bool IsEven(int x) => x % 2 == 0;
_ = new[] { 1, 2, 3 }.Where(IsEven);

Suprimir una advertencia

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

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

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

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

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

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

Para obtener más información, vea Cómo suprimir advertencias de análisis de código.

Consulte también