Quitar expresión lambda innecesaria (IDE0200)
Propiedad | Value |
---|---|
Identificador de la regla | IDE0200 |
Título | Quitar expresión lambda innecesaria |
Categoría | Estilo |
Subcategoría | Reglas del lenguaje (preferencias de bloques de código) |
Lenguajes aplicables | C# 11+ |
Opciones | csharp_style_prefer_method_group_conversion |
Información general
Esta regla marca el uso de una expresión lambda donde no es necesario. Es posible que las expresiones lambda no sean necesarias cuando se cumplan todas las condiciones siguientes:
- 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 proporcionarán 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 se quiere que aplique la regla. Para más información sobre cómo configurar opciones, consulte Formato de opción.
csharp_style_prefer_method_group_conversion
Propiedad | Value | Descripción |
---|---|---|
Nombre de la opción | csharp_style_prefer_method_group_conversion | |
Valores de opción | true |
Se 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);
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 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
del archivo de configuración.
[*.{cs,vb}]
dotnet_diagnostic.IDE0200.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.